From e5e7032af8989dc0634d15fd527d26e2643ff606 Mon Sep 17 00:00:00 2001 From: Chris Wilkinson Date: Mon, 4 Mar 2019 11:06:12 +0000 Subject: [PATCH 1/4] Apply patch to fix Schematron attribute paths --- .gitignore | 1 + bin/update-schematron.php | 28 +++++++++++++++++-- composer.json | 1 + .../iso_schematron_skeleton_for_xslt1.xsl | 1 + tests/SchematronValidatorTest.php | 7 ++++- tests/fixtures/invalid-empty-child.xml | 2 +- tests/fixtures/schema.dtd | 5 +++- tests/fixtures/schema.rng | 12 +++++++- tests/fixtures/schema.sch | 9 +++++- tests/fixtures/schema.xsd | 18 ++++++++++-- 10 files changed, 74 insertions(+), 10 deletions(-) diff --git a/.gitignore b/.gitignore index 592dce7..80956e3 100644 --- a/.gitignore +++ b/.gitignore @@ -3,4 +3,5 @@ /phpcs.xml /phpstan.neon /phpunit.xml +/tmp/ /vendor/ diff --git a/bin/update-schematron.php b/bin/update-schematron.php index c3903d3..8ad500d 100755 --- a/bin/update-schematron.php +++ b/bin/update-schematron.php @@ -3,15 +3,20 @@ declare(strict_types=1); +use Gitonomy\Git; use Symfony\Component\Filesystem\Filesystem; require_once __DIR__.'/../vendor/autoload.php'; $filesystem = new Filesystem(); +$repo = 'https://github.com/Schematron/schematron'; +$repoDir = __DIR__.'/../tmp/schematron'; +$patchesDir = __DIR__.'/../tmp/patches'; $target = __DIR__.'/../lib/schematron'; - -$base = 'https://github.com/Schematron/schematron/raw/master'; +$patches = [ + 'https://github.com/Schematron/schematron/pull/81.patch', +]; $files = [ 'LICENSE', 'trunk/schematron/code/iso_schematron_skeleton_for_xslt1.xsl', @@ -20,8 +25,25 @@ 'trunk/converters/code/ToSchematron/ExtractSchFromXSD.xsl', ]; +if (!$filesystem->exists($repoDir)) { + $filesystem->mkdir(dirname($repoDir)); + Git\Admin::cloneTo($repoDir, $repo, false); +} + +$repository = new Git\Repository($repoDir); + +$repository->run('fetch', ['origin', 'master']); +$repository->run('reset', ['--hard', 'origin/master']); + +foreach ($patches as $patch) { + $patchTarget = "${patchesDir}/".md5($patch); + + $filesystem->copy($patch, $patchTarget); + $repository->run('am', [$patchTarget]); +} + $filesystem->remove(new FilesystemIterator($target)); foreach ($files as $file) { - $filesystem->copy("{$base}/${file}", "{$target}/".basename($file)); + $filesystem->copy("${repoDir}/${file}", "${target}/".basename($file)); } diff --git a/composer.json b/composer.json index 9eb2f0d..f490711 100644 --- a/composer.json +++ b/composer.json @@ -20,6 +20,7 @@ }, "require-dev": { "ext-xsl": "*", + "gitonomy/gitlib": "^1.0", "libero/coding-standard": "^0.3", "phpstan/phpstan": "^0.10", "phpstan/phpstan-phpunit": "^0.10", diff --git a/lib/schematron/iso_schematron_skeleton_for_xslt1.xsl b/lib/schematron/iso_schematron_skeleton_for_xslt1.xsl index 9a764df..2093a01 100644 --- a/lib/schematron/iso_schematron_skeleton_for_xslt1.xsl +++ b/lib/schematron/iso_schematron_skeleton_for_xslt1.xsl @@ -692,6 +692,7 @@ THE SOFTWARE. + / diff --git a/tests/SchematronValidatorTest.php b/tests/SchematronValidatorTest.php index 9d2821a..18b5566 100644 --- a/tests/SchematronValidatorTest.php +++ b/tests/SchematronValidatorTest.php @@ -50,10 +50,15 @@ public function it_fails_on_invalid(string $format) : void $this->assertEquals( [ new Failure( - 'Must not be empty', + 'Element must not be empty', 6, $xpath->query('/example:parent/example:child')->item(0) ), + new Failure( + 'Attribute must not be empty', + 6, + $xpath->query('/example:parent/example:child/@attribute')->item(0) + ), ], $e->getFailures() ); diff --git a/tests/fixtures/invalid-empty-child.xml b/tests/fixtures/invalid-empty-child.xml index 96cbd1a..fa8a3b2 100644 --- a/tests/fixtures/invalid-empty-child.xml +++ b/tests/fixtures/invalid-empty-child.xml @@ -3,6 +3,6 @@ - + diff --git a/tests/fixtures/schema.dtd b/tests/fixtures/schema.dtd index 098c0a7..a601c07 100644 --- a/tests/fixtures/schema.dtd +++ b/tests/fixtures/schema.dtd @@ -4,4 +4,7 @@ - + diff --git a/tests/fixtures/schema.rng b/tests/fixtures/schema.rng index 92e995b..b86ad09 100644 --- a/tests/fixtures/schema.rng +++ b/tests/fixtures/schema.rng @@ -10,10 +10,20 @@ + + + - Must not be empty + Element must not be empty + + + + + + + Attribute must not be empty diff --git a/tests/fixtures/schema.sch b/tests/fixtures/schema.sch index d3890ff..914f744 100644 --- a/tests/fixtures/schema.sch +++ b/tests/fixtures/schema.sch @@ -7,7 +7,14 @@ - Must not be empty + Element must not be empty + + + + + + + Attribute must not be empty diff --git a/tests/fixtures/schema.xsd b/tests/fixtures/schema.xsd index fba1ce9..aea1451 100644 --- a/tests/fixtures/schema.xsd +++ b/tests/fixtures/schema.xsd @@ -12,18 +12,32 @@ - + - Must not be empty + Element must not be empty + + + + + + + Attribute must not be empty + + + + + + + From abbad3d755c240c441314757ae5c756e44d1c036 Mon Sep 17 00:00:00 2001 From: Chris Wilkinson Date: Wed, 6 Mar 2019 07:58:16 +0000 Subject: [PATCH 2/4] Change library and add output --- bin/update-schematron.php | 32 +++++++++++++++++++------------- composer.json | 2 +- 2 files changed, 20 insertions(+), 14 deletions(-) diff --git a/bin/update-schematron.php b/bin/update-schematron.php index 8ad500d..5fd736a 100755 --- a/bin/update-schematron.php +++ b/bin/update-schematron.php @@ -3,17 +3,19 @@ declare(strict_types=1); -use Gitonomy\Git; +use GitWrapper\GitWrapper; use Symfony\Component\Filesystem\Filesystem; require_once __DIR__.'/../vendor/autoload.php'; $filesystem = new Filesystem(); +$git = new GitWrapper(); +$git->streamOutput(); -$repo = 'https://github.com/Schematron/schematron'; +$repoUri = 'https://github.com/Schematron/schematron'; $repoDir = __DIR__.'/../tmp/schematron'; $patchesDir = __DIR__.'/../tmp/patches'; -$target = __DIR__.'/../lib/schematron'; +$targetDir = __DIR__.'/../lib/schematron'; $patches = [ 'https://github.com/Schematron/schematron/pull/81.patch', ]; @@ -26,24 +28,28 @@ ]; if (!$filesystem->exists($repoDir)) { - $filesystem->mkdir(dirname($repoDir)); - Git\Admin::cloneTo($repoDir, $repo, false); + $filesystem->mkdir($repoDir); + $repo = $git->cloneRepository($repoUri, $repoDir, ['depth' => 1]); +} else { + $repo = $git->workingCopy($repoDir); + $repo->fetch('origin', 'master'); + $repo->reset(['hard' => true], 'origin/master'); } -$repository = new Git\Repository($repoDir); - -$repository->run('fetch', ['origin', 'master']); -$repository->run('reset', ['--hard', 'origin/master']); - foreach ($patches as $patch) { $patchTarget = "${patchesDir}/".md5($patch); + echo "Downloading {$patch} to {$patchTarget}\n"; $filesystem->copy($patch, $patchTarget); - $repository->run('am', [$patchTarget]); + $repo->apply($patchTarget, ['verbose' => true]); } -$filesystem->remove(new FilesystemIterator($target)); +$filesystem->remove(new FilesystemIterator($targetDir)); foreach ($files as $file) { - $filesystem->copy("${repoDir}/${file}", "${target}/".basename($file)); + $origin = "${repoDir}/${file}"; + $target = "${targetDir}/".basename($file); + + echo "Copying {$origin} to {$target}\n"; + $filesystem->copy($origin, $target); } diff --git a/composer.json b/composer.json index f490711..3013233 100644 --- a/composer.json +++ b/composer.json @@ -20,7 +20,7 @@ }, "require-dev": { "ext-xsl": "*", - "gitonomy/gitlib": "^1.0", + "cpliakas/git-wrapper": "^2.0", "libero/coding-standard": "^0.3", "phpstan/phpstan": "^0.10", "phpstan/phpstan-phpunit": "^0.10", From 2b1fb4e6bc71fbe7c3b35cebe9b5820dadcbff39 Mon Sep 17 00:00:00 2001 From: Chris Wilkinson Date: Wed, 6 Mar 2019 11:29:40 +0000 Subject: [PATCH 3/4] Add comment --- bin/update-schematron.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bin/update-schematron.php b/bin/update-schematron.php index 5fd736a..34e8899 100755 --- a/bin/update-schematron.php +++ b/bin/update-schematron.php @@ -17,7 +17,7 @@ $patchesDir = __DIR__.'/../tmp/patches'; $targetDir = __DIR__.'/../lib/schematron'; $patches = [ - 'https://github.com/Schematron/schematron/pull/81.patch', + 'https://github.com/Schematron/schematron/pull/81.patch', // Fixes attribute paths. ]; $files = [ 'LICENSE', From 52de032211457e1cc0232e051e1533996dc6bbc0 Mon Sep 17 00:00:00 2001 From: Chris Wilkinson Date: Wed, 6 Mar 2019 11:35:40 +0000 Subject: [PATCH 4/4] Add depth --- bin/update-schematron.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bin/update-schematron.php b/bin/update-schematron.php index 34e8899..3b93f2d 100755 --- a/bin/update-schematron.php +++ b/bin/update-schematron.php @@ -32,7 +32,7 @@ $repo = $git->cloneRepository($repoUri, $repoDir, ['depth' => 1]); } else { $repo = $git->workingCopy($repoDir); - $repo->fetch('origin', 'master'); + $repo->fetch('origin', 'master', ['depth' => 1]); $repo->reset(['hard' => true], 'origin/master'); }