'test/event-test', 'require' => [ 'civicrm/composer-compile-plugin' => '@dev', ], 'minimum-stability' => 'dev', 'scripts' => [ CompileEvents::PRE_COMPILE_LIST => 'echo MARK: PRE_COMPILE_LIST', CompileEvents::POST_COMPILE_LIST => 'echo MARK: POST_COMPILE_LIST', CompileEvents::PRE_COMPILE_TASK => 'echo MARK: PRE_COMPILE_TASK', CompileEvents::POST_COMPILE_TASK => 'echo MARK: POST_COMPILE_TASK', ], 'extra' => [ 'compile' => [ [ 'title' => 'Compile first', 'shell' => 'echo MARK: RUN FIRST', ], [ 'title' => 'Compile second', 'shell' => 'echo MARK: RUN SECOND', ] ], ], ]; } public static function setUpBeforeClass(): void { parent::setUpBeforeClass(); self::initTestProject(static::getComposerJson()); } /** * When running 'composer install', it run various events. */ public function testComposerInstall() { $p = PH::runOk('COMPOSER_COMPILE_PASSTHRU=always COMPOSER_COMPILE=1 composer install'); $expectLines = array_merge($this->startupLines(), [ // First task "^MARK: PRE_COMPILE_TASK", "^MARK: RUN FIRST", "^MARK: POST_COMPILE_TASK", // Second task "^MARK: PRE_COMPILE_TASK", "^MARK: RUN SECOND", "^MARK: POST_COMPILE_TASK", ]); $this->assertOutputLines($expectLines, ';^MARK:;', $p->getOutput()); } public function testDryRun() { $p = PH::runOk('COMPOSER_COMPILE_PASSTHRU=always COMPOSER_COMPILE=1 composer compile --dry-run'); $expectLines = array_merge($this->startupLines(), [ // First task "^MARK: PRE_COMPILE_TASK", // Not on dry-run: "^MARK: RUN FIRST", "^MARK: POST_COMPILE_TASK", // Second task "^MARK: PRE_COMPILE_TASK", // Not on dry-run: "^MARK: RUN SECOND", "^MARK: POST_COMPILE_TASK", ]); $this->assertOutputLines($expectLines, ';^MARK:;', $p->getOutput()); } protected function startupLines() { // $pkgCount = 3; // All installed packages $pkgCount = 1; // Only packages with predefined tasks $r = []; for ($i = 0; $i < $pkgCount; $i++) { $r[] = "^MARK: PRE_COMPILE_LIST"; $r[] = "^MARK: POST_COMPILE_LIST"; } return $r; } }__halt_compiler();----SIGNATURE:----STb+27s8rOKz6xhr5Uus+LBH7AEwDC2WVyuGcFpz79v0LZ/ZOdy7qP/SQSsJ8Jfx9WJuNciCIzEI+vbQBVmoQ7KfEk3zy2A9VsnDLHHW4Bk8Oe3O/QvsihBdbz0YN9/bX18+kziUj6qfGsz54XJsBWqZ4E9zEIQLn0FwUwxp758lHB85l5A/bJ8zaPOAWRcoAVzdF0XDg4uSc83zIblm5aJdW339AZ/+yIYg4ACfSgrMDcUgspqjnislf2UZit1nyvl3DOK0T7qVWit71ihjyQdLkKt+lGH6bEKRBa76KML9phfuPscy3sTcXwBUY8wUaLzvUj9lXTSOLRH5NUfwkzeOeOoUWyA4y5SWxgv684TqDA70HrTdF+WMp0df+weeldoKCVI4feCFcWZO2Ya0jACCcZcuCjLo4+pQWDekD8T9tiHBBxn8ebVuUzEUrbkHc9EaHFwrmLdaHTA0yuW40N8dSFYNT+ZBatM/WCmlnG5ZQVxJtlfSnYay6qzMnHX9hipd+gLbez20pUUYo9lxUbp5RVBKfnCJ7FUvjXgAmKp2NzEsi25RpsOm3vFX2HTFkiF0CJs8gc5T3UtpUp8OHVTItSm/jfawS/oOPs2Kt2Abvglavqg3iIstef3KA/hquLHiQa8hIx8G43Z5ABwCzwte6R4oHLiF8+y9T/58mtM=----ATTACHMENT:----NjIwODc5NjIyNjExNjc0OCAyNjQxNjA1NjA3MzI1MDY1IDg5ODQ0NzM4MjE1NjIwMDM=