diff options
| -rw-r--r-- | .gitattributes | 3 | ||||
| -rw-r--r-- | tests/unit/Web/TAssetManagerTest.php | 162 | ||||
| -rw-r--r-- | tests/unit/Web/data/aTarFile.md5 | 1 | ||||
| -rw-r--r-- | tests/unit/Web/data/aTarFile.tar | bin | 0 -> 20480 bytes | |||
| -rw-r--r-- | tests/unit/Web/data/pradoheader.gif | bin | 0 -> 15430 bytes | 
5 files changed, 151 insertions, 15 deletions
| diff --git a/.gitattributes b/.gitattributes index da462222..a0576804 100644 --- a/.gitattributes +++ b/.gitattributes @@ -2994,6 +2994,9 @@ tests/unit/Web/UI/WebControls/TRequiredFieldValidatorTest.php -text  tests/unit/Web/UI/WebControls/TXmlTransformTest.php -text  tests/unit/Web/UI/WebControls/data/hello.xml -text  tests/unit/Web/UI/WebControls/data/hello.xsl -text +tests/unit/Web/data/aTarFile.md5 -text +tests/unit/Web/data/aTarFile.tar -text +tests/unit/Web/data/pradoheader.gif -text  tests/unit/Xml/AllTests.php -text  tests/unit/Xml/TRssFeedDocumentTest.php -text  tests/unit/Xml/TXmlDocumentTest.php -text diff --git a/tests/unit/Web/TAssetManagerTest.php b/tests/unit/Web/TAssetManagerTest.php index 49d42165..14dbf872 100644 --- a/tests/unit/Web/TAssetManagerTest.php +++ b/tests/unit/Web/TAssetManagerTest.php @@ -8,24 +8,156 @@ Prado::using('System.Web.TAssetManager');   */  class TAssetManagerTest extends PHPUnit_Framework_TestCase { -  public function testInit() { -    throw new PHPUnit_Framework_IncompleteTestError(); -  } +	public static $app = null; +	public static $assetDir = null; -  public function testSetBasePath() { -    throw new PHPUnit_Framework_IncompleteTestError(); -  } +	public function setUp () { +		// Fake environment variables needed to determine path +		$_SERVER['HTTP_HOST'] = 'localhost'; +		$_SERVER['SERVER_NAME'] = 'localhost'; +		$_SERVER['SERVER_PORT'] = '80'; +		$_SERVER['REQUEST_METHOD'] = 'GET'; +		$_SERVER['REQUEST_URI'] = '/demos/personal/index.php?page=Links'; +		$_SERVER['SCRIPT_NAME'] = '/demos/personal/index.php'; +		$_SERVER['PHP_SELF'] = '/demos/personal/index.php'; +		$_SERVER['QUERY_STRING'] = 'page=Links'; +		$_SERVER['SCRIPT_FILENAME'] = __FILE__; +		$_SERVER['PATH_INFO'] = __FILE__; +		$_SERVER['HTTP_REFERER'] = 'http://www.pradosoft.com'; +		$_SERVER['REMOTE_ADDR'] = '127.0.0.1'; +		$_SERVER['HTTP_USER_AGENT'] = 'Mozilla/5.0 (Macintosh; U; Intel Mac OS X; en-US; rv:1.8.1.3) Gecko/20070309 Firefox/2.0.0.3'; +		$_SERVER['REMOTE_HOST'] = 'localhost'; +		 +		if (self::$app===null) { +			self::$app=new TApplication(dirname(__FILE__).'/app'); +		} +		 +		if (self::$assetDir===null) self::$assetDir= dirname(__FILE__).'/assets'; +		// Make asset directory if not exists  +		// this will fail test if current directory not writable. +		@mkdir (self::$assetDir); +		// Define an alias to asset directory +		prado::setPathofAlias('AssetAlias', self::$assetDir); +		 +	} +	 +	public function tearDown () { +		// Make some cleaning :) +		@rmdir (self::$assetDir); +	} +	 +	public function testInit() { +		 +		$manager=new TAssetManager (); -  public function testSetBaseUrl() { -    throw new PHPUnit_Framework_IncompleteTestError(); -  } +		$manager->init (null); +		 +		self::assertEquals(self::$assetDir, $manager->getBasePath()); +		self::assertEquals($manager, self::$app->getAssetManager()); +		 +		// No, remove asset directory, and catch the exception +		if (is_dir(self::$assetDir)) rmdir (self::$assetDir); +		try { +			$manager->init (null); +			self::fail ('Expected TConfigurationException not thrown'); +		} catch (TConfigurationException $e) {} +	} -  public function testPublishFilePath() { -    throw new PHPUnit_Framework_IncompleteTestError(); -  } +	public function testSetBasePath() { +		$manager = new TAssetManager (); +		// First try, invalid directory +		try { +			$manager->setBasePath('invalid'); +			self::fail('Expected TInvalidDataValueException not thrown'); +		} catch (TInvalidDataValueException $e) {} +		 +		// Next, standard asset directory, should work +		 +		$manager->setBasePath ('AssetAlias'); +		self::assertEquals(self::$assetDir, $manager->getBasePath()); +		 +		// Finally, test to change after init +		$manager->init (null); +		try { +			$manager->setBasePath ('test'); +			self::fail ('Expected TInvalidOperationException not thrown'); +		} catch (TInvalidOperationException $e) {} -  public function testPublishTarFile() { -    throw new PHPUnit_Framework_IncompleteTestError(); -  } +	} + +	public function testSetBaseUrl() { +		$manager=new TAssetManager (); +		$manager->setBaseUrl ('/assets/'); +		self::assertEquals("/assets", $manager->getBaseUrl()); +	 +		$manager->init (null); +		try { +			$manager->setBaseUrl ('/test'); +			self::fail ('Expected TInvalidOperationException not thrown'); +		} catch (TInvalidOperationException $e) {} +		 +	} + +	public function testPublishFilePath() { +		$manager=new TAssetManager(); +		$manager->setBaseUrl('/'); +		$manager->init (null); +		 +		// Try to publish a single file +	    $fileToPublish=dirname(__FILE__).'/data/pradoheader.gif'; +		$publishedUrl = $manager->publishFilePath($fileToPublish); +		$publishedFile=self::$assetDir.$publishedUrl; +		self::assertEquals($publishedFile, $manager->getPublishedPath($fileToPublish)); +		self::assertEquals($publishedUrl, $manager->getPublishedUrl($fileToPublish)); +		self::assertTrue(is_file($publishedFile)); +		@unlink ($publishedFile); +		@rmdir (dirname($publishedFile)); +		 +		// Try to publish a directory +	    $dirToPublish=dirname(__FILE__).'/data'; +		$publishedUrl = $manager->publishFilePath($dirToPublish); +		$publishedDir=self::$assetDir.$publishedUrl; +		self::assertEquals($publishedDir, $manager->getPublishedPath($dirToPublish)); +		self::assertEquals($publishedUrl, $manager->getPublishedUrl($dirToPublish)); +		self::assertTrue(is_dir($publishedDir)); +		self::assertTrue(is_file($publishedDir.'/pradoheader.gif')); +		@unlink ($publishedDir.'/pradoheader.gif'); +		@rmdir ($publishedDir.'/aDirectory'); +		@unlink ($publishedDir.'/aTarFile.tar'); +		@unlink ($publishedDir.'/aTarFile.md5'); +		@rmdir ($publishedDir); +		 +		// Finally, try to publish invalid file +	    try { +	      $manager->publishFilePath('invalid_file'); +	      self::fail('Expected TInvalidDataValueException not thrown'); +	    } catch (TInvalidDataValueException $e) {} +	} + +	public function testPublishTarFile() { +		$manager=new TAssetManager(); +		$manager->setBaseUrl('/'); +		$manager->init (null); +		 +		$tarFile=dirname(__FILE__).'/data/aTarFile.tar'; +		$md5File=dirname(__FILE__).'/data/aTarFile.md5'; +		 +		// First, try with bad md5 +	    try { +	      $manager->publishTarFile($tarFile, 'badMd5File'); +	      self::fail('Expected Expected TInvalidDataValueException not thrown'); +	    } catch (TInvalidDataValueException $e) {} +	     +	    // Then, try with real md5 file +	    $publishedUrl=$manager->publishTarFile($tarFile, $md5File); +	    $publishedDir=self::$assetDir.$publishedUrl; +	    self::assertTrue(is_dir($publishedDir)); +	    self::assertTrue(is_file($publishedDir.'/pradoheader.gif')); +	    self::assertTrue(is_file($publishedDir.'/aTarFile.md5')); +	    @unlink ($publishedDir.'/pradoheader.gif'); +	    @unlink ($publishedDir.'/aTarFile.md5'); +	    @rmdir ($publishedDir.'/aDirectory'); +	    @rmdir ($publishedDir); +	}  }  ?>
\ No newline at end of file diff --git a/tests/unit/Web/data/aTarFile.md5 b/tests/unit/Web/data/aTarFile.md5 new file mode 100644 index 00000000..56401e2c --- /dev/null +++ b/tests/unit/Web/data/aTarFile.md5 @@ -0,0 +1 @@ +4b1ecb0b243918a8bbfbb4515937be98  aTarFile.tar diff --git a/tests/unit/Web/data/aTarFile.tar b/tests/unit/Web/data/aTarFile.tarBinary files differ new file mode 100644 index 00000000..fb4ae3b9 --- /dev/null +++ b/tests/unit/Web/data/aTarFile.tar diff --git a/tests/unit/Web/data/pradoheader.gif b/tests/unit/Web/data/pradoheader.gifBinary files differ new file mode 100644 index 00000000..40ca5d29 --- /dev/null +++ b/tests/unit/Web/data/pradoheader.gif | 
