Refactor L10n for testing
- Moving L10n to L10n\L10n - Adding constructor information - Adding to factory - simplify/speedup tests
This commit is contained in:
		
					parent
					
						
							
								966043712f
							
						
					
				
			
			
				commit
				
					
						eb024a3718
					
				
			
		
					 13 changed files with 596 additions and 450 deletions
				
			
		|  | @ -1,69 +1,67 @@ | |||
| <?php | ||||
| /** | ||||
|  * Created by PhpStorm. | ||||
|  * User: benlo | ||||
|  * Date: 25/03/19 | ||||
|  * Time: 21:36 | ||||
|  */ | ||||
| 
 | ||||
| namespace Friendica\Test\src\Content; | ||||
| 
 | ||||
| use Friendica\Content\Smilies; | ||||
| use Friendica\Test\MockedTest; | ||||
| use Friendica\Test\Util\AppMockTrait; | ||||
| use Friendica\Test\Util\L10nMockTrait; | ||||
| use Friendica\Test\Util\VFSTrait; | ||||
| 
 | ||||
| class SmiliesTest extends MockedTest | ||||
| { | ||||
| 	use VFSTrait; | ||||
| 	use AppMockTrait; | ||||
| 	use L10nMockTrait; | ||||
| 
 | ||||
| 	protected function setUp() | ||||
| 	{ | ||||
| 		parent::setUp(); | ||||
| 		$this->setUpVfsDir(); | ||||
| 		$this->mockApp($this->root); | ||||
| 		$this->app->videowidth = 425; | ||||
| 		$this->app->videoheight = 350; | ||||
| 		$this->configMock->shouldReceive('get') | ||||
| 			->with('system', 'no_smilies') | ||||
| 			->andReturn(false); | ||||
| 		$this->configMock->shouldReceive('get') | ||||
| 			->with(false, 'system', 'no_smilies') | ||||
| 			->andReturn(false); | ||||
| 	} | ||||
| 
 | ||||
| 	public function dataLinks() | ||||
| 	{ | ||||
| 		return [ | ||||
| 			/** @see https://github.com/friendica/friendica/pull/6933 */ | ||||
| 			'bug-6933-1' => [ | ||||
| 				'data' => '<code>/</code>', | ||||
| 				'smilies' => ['texts' => [], 'icons' => []], | ||||
| 				'expected' => '<code>/</code>', | ||||
| 			], | ||||
| 			'bug-6933-2' => [ | ||||
| 				'data' => '<code>code</code>', | ||||
| 				'smilies' => ['texts' => [], 'icons' => []], | ||||
| 				'expected' => '<code>code</code>', | ||||
| 			], | ||||
| 		]; | ||||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
| 	 * Test replace smilies in different texts | ||||
| 	 * @dataProvider dataLinks | ||||
| 	 * | ||||
| 	 * @param string $text     Test string | ||||
| 	 * @param array  $smilies  List of smilies to replace | ||||
| 	 * @param string $expected Expected result | ||||
| 	 * @throws \Friendica\Network\HTTPException\InternalServerErrorException | ||||
| 	 */ | ||||
| 	public function testReplaceFromArray($text, $smilies, $expected) | ||||
| 	{ | ||||
| 		$output = Smilies::replaceFromArray($text, $smilies); | ||||
| 		$this->assertEquals($expected, $output); | ||||
| 	} | ||||
| } | ||||
| <?php | ||||
| /** | ||||
|  * Created by PhpStorm. | ||||
|  * User: benlo | ||||
|  * Date: 25/03/19 | ||||
|  * Time: 21:36 | ||||
|  */ | ||||
| 
 | ||||
| namespace Friendica\Test\src\Content; | ||||
| 
 | ||||
| use Friendica\Content\Smilies; | ||||
| use Friendica\Test\MockedTest; | ||||
| use Friendica\Test\Util\AppMockTrait; | ||||
| use Friendica\Test\Util\VFSTrait; | ||||
| 
 | ||||
| class SmiliesTest extends MockedTest | ||||
| { | ||||
| 	use VFSTrait; | ||||
| 	use AppMockTrait; | ||||
| 
 | ||||
| 	protected function setUp() | ||||
| 	{ | ||||
| 		parent::setUp(); | ||||
| 		$this->setUpVfsDir(); | ||||
| 		$this->mockApp($this->root); | ||||
| 		$this->app->videowidth = 425; | ||||
| 		$this->app->videoheight = 350; | ||||
| 		$this->configMock->shouldReceive('get') | ||||
| 			->with('system', 'no_smilies') | ||||
| 			->andReturn(false); | ||||
| 		$this->configMock->shouldReceive('get') | ||||
| 			->with(false, 'system', 'no_smilies') | ||||
| 			->andReturn(false); | ||||
| 	} | ||||
| 
 | ||||
| 	public function dataLinks() | ||||
| 	{ | ||||
| 		return [ | ||||
| 			/** @see https://github.com/friendica/friendica/pull/6933 */ | ||||
| 			'bug-6933-1' => [ | ||||
| 				'data' => '<code>/</code>', | ||||
| 				'smilies' => ['texts' => [], 'icons' => []], | ||||
| 				'expected' => '<code>/</code>', | ||||
| 			], | ||||
| 			'bug-6933-2' => [ | ||||
| 				'data' => '<code>code</code>', | ||||
| 				'smilies' => ['texts' => [], 'icons' => []], | ||||
| 				'expected' => '<code>code</code>', | ||||
| 			], | ||||
| 		]; | ||||
| 	} | ||||
| 
 | ||||
| 	/** | ||||
| 	 * Test replace smilies in different texts | ||||
| 	 * @dataProvider dataLinks | ||||
| 	 * | ||||
| 	 * @param string $text     Test string | ||||
| 	 * @param array  $smilies  List of smilies to replace | ||||
| 	 * @param string $expected Expected result | ||||
| 	 * @throws \Friendica\Network\HTTPException\InternalServerErrorException | ||||
| 	 */ | ||||
| 	public function testReplaceFromArray($text, $smilies, $expected) | ||||
| 	{ | ||||
| 		$output = Smilies::replaceFromArray($text, $smilies); | ||||
| 		$this->assertEquals($expected, $output); | ||||
| 	} | ||||
| } | ||||
|  |  | |||
|  | @ -3,20 +3,15 @@ | |||
| namespace Friendica\Test\src\Content\Text; | ||||
| 
 | ||||
| use Friendica\Content\Text\BBCode; | ||||
| use Friendica\Core\L10n\L10n; | ||||
| use Friendica\Test\MockedTest; | ||||
| use Friendica\Test\Util\AppMockTrait; | ||||
| use Friendica\Test\Util\L10nMockTrait; | ||||
| use Friendica\Test\Util\VFSTrait; | ||||
| 
 | ||||
| /** | ||||
|  * @runTestsInSeparateProcesses | ||||
|  * @preserveGlobalState disabled | ||||
|  */ | ||||
| class BBCodeTest extends MockedTest | ||||
| { | ||||
| 	use VFSTrait; | ||||
| 	use AppMockTrait; | ||||
| 	use L10nMockTrait; | ||||
| 
 | ||||
| 	protected function setUp() | ||||
| 	{ | ||||
|  | @ -43,7 +38,11 @@ class BBCodeTest extends MockedTest | |||
| 		$this->configMock->shouldReceive('get') | ||||
| 			->with('system', 'no_smilies') | ||||
| 			->andReturn(false); | ||||
| 		$this->mockL10nT(); | ||||
| 
 | ||||
| 		$l10nMock = \Mockery::mock(L10n::class); | ||||
| 		$l10nMock->shouldReceive('t')->withAnyArgs()->andReturnUsing(function ($args) { return $args; }); | ||||
| 		\Friendica\Core\L10n::init($l10nMock); | ||||
| 
 | ||||
| 	} | ||||
| 
 | ||||
| 	public function dataLinks() | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue