From e613c47cd62133f1b35a5498555fecb668110a3d Mon Sep 17 00:00:00 2001 From: Michael Reichardt Date: Tue, 19 Mar 2024 18:47:10 +0100 Subject: [PATCH] Add e2e tests --- .../Blueprints/Model/BlueprintBuilder.php | 2 + src/WordPress/Blueprints/functions.php | 3 +- tests/e2e/JsonBlueprintTest.php | 123 +++++++++++++++++ tests/e2e/PhpBlueprintTest.php | 125 ++++++++++++++++++ tests/e2e/configuration/E2ETestCase.php | 5 + tests/unit/json_mapper/JsonMapperTest.php | 13 +- 6 files changed, 263 insertions(+), 8 deletions(-) create mode 100644 tests/e2e/JsonBlueprintTest.php create mode 100644 tests/e2e/PhpBlueprintTest.php create mode 100644 tests/e2e/configuration/E2ETestCase.php diff --git a/src/WordPress/Blueprints/Model/BlueprintBuilder.php b/src/WordPress/Blueprints/Model/BlueprintBuilder.php index 0a3abc53..d2f37fcf 100644 --- a/src/WordPress/Blueprints/Model/BlueprintBuilder.php +++ b/src/WordPress/Blueprints/Model/BlueprintBuilder.php @@ -31,6 +31,8 @@ class BlueprintBuilder { public function __construct() { $this->blueprint = new Blueprint(); + $this->blueprint->setConstants( new \ArrayObject() ); + $this->blueprint->setSiteOptions( new \ArrayObject() ); } public static function create() { diff --git a/src/WordPress/Blueprints/functions.php b/src/WordPress/Blueprints/functions.php index 83d233bc..3c3b56f9 100644 --- a/src/WordPress/Blueprints/functions.php +++ b/src/WordPress/Blueprints/functions.php @@ -18,11 +18,10 @@ function run_blueprint( $json, $options = array() ) { $environment, new Runtime( $documentRoot ) ); - + /** @var $engine Engine */ $engine = $c['blueprint.engine']; $compiledBlueprint = $engine->parseAndCompile( $json ); - /** @var $engine Engine */ if ( $progressSubscriber ) { if ( $progressType === 'steps' ) { $compiledBlueprint->stepsProgressStage->events->addSubscriber( $progressSubscriber ); diff --git a/tests/e2e/JsonBlueprintTest.php b/tests/e2e/JsonBlueprintTest.php new file mode 100644 index 00000000..35f9566e --- /dev/null +++ b/tests/e2e/JsonBlueprintTest.php @@ -0,0 +1,123 @@ +document_root = Path::makeAbsolute( 'test', sys_get_temp_dir() ); + + $this->subscriber = new class() implements EventSubscriberInterface { + public static function getSubscribedEvents() { + return array( + ProgressEvent::class => 'onProgress', + DoneEvent::class => 'onDone', + ); + } + + protected $progress_bar; + + public function __construct() { + ProgressBar::setFormatDefinition( 'custom', ' [%bar%] %current%/%max% -- %message%' ); + + $this->progress_bar = ( new SymfonyStyle( + new StringInput( '' ), + new ConsoleOutput() + ) )->createProgressBar( 100 ); + $this->progress_bar->setFormat( 'custom' ); + $this->progress_bar->setMessage( 'Start' ); + $this->progress_bar->start(); + } + + public function onProgress( ProgressEvent $event ) { + $this->progress_bar->setMessage( $event->caption ); + $this->progress_bar->setProgress( (int) $event->progress ); + } + + public function onDone( DoneEvent $event ) { + $this->progress_bar->finish(); + } + }; + } + + /** + * @after + */ + public function after() { + ( new Filesystem() )->remove( $this->document_root ); + } + public function testRunningJsonBlueprintWithWordPressVersion() { + $blueprint = '{"WordPressVersion":"https://wordpress.org/latest.zip"}'; + + $results = run_blueprint( + $blueprint, + array( + 'environment' => ContainerBuilder::ENVIRONMENT_NATIVE, + 'documentRoot' => $this->document_root . '/new-wp', + 'progressSubscriber' => $this->subscriber, + ) + ); + + // fails at downloadWordPress + + $expected = array( +// 0 => new StepSuccess(), +// 1 => new StepSuccess(), +// 2 => new StepSuccess(), +// 3 => new StepSuccess(), + ); + + // @TODO fix expected + $this->assertEquals( $expected, $results ); + } + + public function testRunningJsonBlueprintWithSteps() { + $blueprint = '{"steps":[{"step":"mkdir","path":"dir"},{"step": "rm","path": "dir"}]}'; + + $results = run_blueprint( + $blueprint, + array( + 'environment' => ContainerBuilder::ENVIRONMENT_NATIVE, + 'documentRoot' => $this->document_root . '/new-wp', + 'progressSubscriber' => $this->subscriber, + ) + ); + + // fails at defineWpConfigConsts + + $expected = array( +// 0 => new StepSuccess(), +// 1 => new StepSuccess(), +// 2 => new StepSuccess(), +// 3 => new StepSuccess(), + ); + + // @TODO fix expected + $this->assertEquals( $expected, $results ); + } +} \ No newline at end of file diff --git a/tests/e2e/PhpBlueprintTest.php b/tests/e2e/PhpBlueprintTest.php new file mode 100644 index 00000000..d809d098 --- /dev/null +++ b/tests/e2e/PhpBlueprintTest.php @@ -0,0 +1,125 @@ +document_root = Path::makeAbsolute( 'test', sys_get_temp_dir() ); + + $this->subscriber = new class() implements EventSubscriberInterface { + public static function getSubscribedEvents() { + return array( + ProgressEvent::class => 'onProgress', + DoneEvent::class => 'onDone', + ); + } + + protected $progress_bar; + + public function __construct() { + ProgressBar::setFormatDefinition( 'custom', ' [%bar%] %current%/%max% -- %message%' ); + + $this->progress_bar = ( new SymfonyStyle( + new StringInput( '' ), + new ConsoleOutput() + ) )->createProgressBar( 100 ); + $this->progress_bar->setFormat( 'custom' ); + $this->progress_bar->setMessage( 'Start' ); + $this->progress_bar->start(); + } + + public function onProgress( ProgressEvent $event ) { + $this->progress_bar->setMessage( $event->caption ); + $this->progress_bar->setProgress( (int) $event->progress ); + } + + public function onDone( DoneEvent $event ) { + $this->progress_bar->finish(); + } + }; + } + + /** + * @after + */ + public function after() { + ( new Filesystem() )->remove( $this->document_root ); + } + + public function testRunningPhpBlueprintWithWordPressVersion() { + $blueprint = BlueprintBuilder::create() + ->withWordPressVersion( 'https://wordpress.org/latest.zip' ) + ->toBlueprint(); + + $results = run_blueprint( + $blueprint, + array( + 'environment' => ContainerBuilder::ENVIRONMENT_NATIVE, + 'documentRoot' => $this->document_root . '/new-wp', + 'progressSubscriber' => $this->subscriber, + ) + ); + + $expected = array(); + + // @TODO fix expected + $this->assertEquals( $expected, $results ); + } + + public function testRunningPhpBlueprintWithSteps() { + $blueprint = BlueprintBuilder::create() + ->addStep( ( new MkdirStep() )->setPath( 'dir1' ) ) + ->addStep( ( new RmStep() )->setPath( 'dir1' ) ) + ->addStep( ( new MkdirStep() )->setPath( 'dir2' ) ) + ->toBlueprint(); + + $results = run_blueprint( + $blueprint, + array( + 'environment' => ContainerBuilder::ENVIRONMENT_NATIVE, + 'documentRoot' => $this->document_root . '/new-wp', + 'progressSubscriber' => $this->subscriber, + ) + ); + + $expected = array(); + array( + 0 => new StepSuccess( new MkdirStep(), true ), + 1 => new StepSuccess( new RmStep(), true ), + 2 => new StepSuccess( new MkdirStep(), true ), + ); + + // @TODO fix expected + $this->assertEquals( $expected, $results ); + } +} diff --git a/tests/e2e/configuration/E2ETestCase.php b/tests/e2e/configuration/E2ETestCase.php new file mode 100644 index 00000000..544ca2dd --- /dev/null +++ b/tests/e2e/configuration/E2ETestCase.php @@ -0,0 +1,5 @@ + function ( $json ) { $item = new Item(); $item->name = $json->name; return $item; }, - ) ); - - $result = $mapper->hydrate( - json_decode( '{"name":"test","items":[{"name":"test"}]}' ), - Bag::class ); + $mapper = new JsonMapper($custom_factories); + + $raw_json = '{"name":"test","items":[{"name":"test"}]}'; + + $result = $mapper->hydrate( json_decode( $raw_json ), Bag::class ); + $expected = new Bag(); $expected->name = 'test'; $expected->items = [ new Item() ];