request('GET', '/datafiles/' . self::$DI['record_1']->get_sbas_id() . '/' . self::$DI['record_1']->get_record_id() . '/preview/'); $response = self::$DI['client']->getResponse(); $this->assertEquals(200, $response->getStatusCode()); $content_disposition = explode(';', $response->headers->get('content-disposition')); $this->assertEquals('inline', $content_disposition[0]); $this->assertEquals(self::$DI['record_1']->get_preview()->get_mime(), $response->headers->get('content-type')); $this->assertEquals(self::$DI['record_1']->get_preview()->get_size(), $response->headers->get('content-length')); } /** * @expectedException Symfony\Component\HttpKernel\Exception\NotFoundHttpException */ function testDatafilesNonExistentSubdef() { $crawler = self::$DI['client']->request('GET', '/datafiles/' . self::$DI['record_1']->get_sbas_id() . '/' . self::$DI['record_1']->get_record_id() . '/asubdefthatdoesnotexists/'); } function testEtag() { $tmp = tempnam(sys_get_temp_dir(), 'testEtag'); copy(__DIR__ . '/../../../testfiles/cestlafete.jpg', $tmp); $media = self::$DI['app']['mediavorus']->guess($tmp); $file = new Alchemy\Phrasea\Border\File($media, self::$DI['collection']); $record = record_adapter::createFromFile($file, self::$DI['app']); $record->generate_subdefs($record->get_databox(), self::$DI['app']); $crawler = self::$DI['client']->request('GET', '/datafiles/' . $record->get_sbas_id() . '/' . $record->get_record_id() . '/preview/'); $response = self::$DI['client']->getResponse(); /* @var $response \Symfony\Component\HttpFoundation\Response */ $this->assertTrue($response->isOk()); $this->assertNotNull($response->getEtag()); $this->assertInstanceOf('DateTime', $response->getLastModified()); $this->assertNull($response->getMaxAge()); $this->assertNull($response->getTtl()); $this->assertGreaterThanOrEqual(0, $response->getAge()); $this->assertNull($response->getExpires()); unlink($tmp); } function testDatafilesRouteNotAuthenticated() { $appbox = self::$DI['app']['phraseanet.appbox']; self::$DI['app']->closeAccount(); $crawler = self::$DI['client']->request('GET', '/datafiles/' . self::$DI['record_1']->get_sbas_id() . '/' . self::$DI['record_1']->get_record_id() . '/preview/'); $response = self::$DI['client']->getResponse(); $this->assertEquals(403, $response->getStatusCode()); $crawler = self::$DI['client']->request('GET', '/datafiles/' . self::$DI['record_1']->get_sbas_id() . '/' . self::$DI['record_1']->get_record_id() . '/notfoundreview/'); $response = self::$DI['client']->getResponse(); $this->assertEquals(403, $response->getStatusCode()); } function testPermalinkAuthenticated() { $appbox = self::$DI['app']['phraseanet.appbox']; $this->assertTrue(self::$DI['app']->isAuthenticated()); $this->get_a_permalink(); } function testPermalinkNotAuthenticated() { $appbox = self::$DI['app']['phraseanet.appbox']; self::$DI['app']->closeAccount(); $this->assertFalse(self::$DI['app']->isAuthenticated()); $this->get_a_permalink(); } protected function get_a_permalink() { $token = self::$DI['record_1']->get_preview()->get_permalink()->get_token(); $url = '/permalink/v1/whateverIwannt/' . self::$DI['record_1']->get_sbas_id() . '/' . self::$DI['record_1']->get_record_id() . '/' . $token . '/preview/'; $crawler = self::$DI['client']->request('GET', $url); $response = self::$DI['client']->getResponse(); $this->assertEquals(200, $response->getStatusCode()); $url = $url . 'view/'; $crawler = self::$DI['client']->request('GET', $url); $response = self::$DI['client']->getResponse(); $this->assertEquals(200, $response->getStatusCode()); } }