From cec3475a72f4d9481158748cec7129c238429ec6 Mon Sep 17 00:00:00 2001 From: otsch Date: Fri, 1 Dec 2023 02:03:08 +0100 Subject: [PATCH] Add forgotten getter method Add forgotten getter method to get the DOM query that is attached to an `InvalidDomQueryException` instance. --- CHANGELOG.md | 4 +++ .../Exceptions/InvalidDomQueryException.php | 5 +++ .../InvalidDomQueryExceptionTest.php | 34 +++++++++++++++++++ 3 files changed, 43 insertions(+) create mode 100644 tests/Steps/Html/Exceptions/InvalidDomQueryExceptionTest.php diff --git a/CHANGELOG.md b/CHANGELOG.md index 084db754..f22c826e 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] +## [1.3.3] - 2023-12-01 +### Fixed +* Add forgotten getter method to get the DOM query that is attached to an `InvalidDomQueryException` instance. + ## [1.3.2] - 2023-12-01 ### Fixed * When creating a `CssSelector` or `XPathQuery` instance with invalid selector/query syntax, an `InvalidDomQueryException` is now immediately thrown. This change is considered to be not only non-breaking, but actually a fix, because the `CssSelector` would otherwise throw an exception later when the `apply()` method is called. The `XPathQuery` would silently return no result without notifying you of the invalid query and generate a PHP warning. diff --git a/src/Steps/Html/Exceptions/InvalidDomQueryException.php b/src/Steps/Html/Exceptions/InvalidDomQueryException.php index 9c414b69..f53677e4 100644 --- a/src/Steps/Html/Exceptions/InvalidDomQueryException.php +++ b/src/Steps/Html/Exceptions/InvalidDomQueryException.php @@ -38,4 +38,9 @@ public function setDomQuery(string $domQuery): void { $this->query = $domQuery; } + + public function getDomQuery(): string + { + return $this->query; + } } diff --git a/tests/Steps/Html/Exceptions/InvalidDomQueryExceptionTest.php b/tests/Steps/Html/Exceptions/InvalidDomQueryExceptionTest.php new file mode 100644 index 00000000..cdf8e046 --- /dev/null +++ b/tests/Steps/Html/Exceptions/InvalidDomQueryExceptionTest.php @@ -0,0 +1,34 @@ +getDomQuery()) + ->toBe('.foo:before') + ->and($exception->getMessage()) + ->toBe('error'); +}); + +it('can be created from a symfony SyntaxErrorException', function () { + $exception = InvalidDomQueryException::fromSymfonyException('.foo;', new SyntaxErrorException('error message')); + + expect($exception->getDomQuery()) + ->toBe('.foo;') + ->and($exception->getMessage()) + ->toBe('error message'); +}); + +it('can be created from a message and a query', function () { + $exception = InvalidDomQueryException::make('message', '.foo > .bar;'); + + expect($exception->getDomQuery()) + ->toBe('.foo > .bar;') + ->and($exception->getMessage()) + ->toBe('message'); +});