-
Notifications
You must be signed in to change notification settings - Fork 155
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add more selector edge case tests #1135
Comments
Though OTOH, we should trust the reliability of the 3rd party libraries (to parse the CSS and convert the selectors to XPaths) and thus adding our own tests is duplicating effort. |
This is connected that we're kind of mixing up unit tests and functional tests in our tests: Unit tests should test only one class (and how it interacts with the environment, while the 3rd-party code should not be executed), while functional tests should test multiple parts of the system together (with our code possibly calling 3rd-parts code). As a more pragmatic approach, I propose we
WDYT? |
I guess the situation we currently have has arisen because originally there was just one class. As we have refactored functionality into other classes or 3rd-party libraries we have often retained the original tests whilst adding new test cases for the new classes. The above approach makes sense. There are probably quite a few test methods in CssInlinerTest that belong elsewhere. |
Reviewing the tests in For one thing, I think we can move selector precedence calculation to a separate class and test that independently. |
Possibly using PHP's Comparable |
We should reorder the tests in This will help us identify areas for refactoring. It could be done as a single commit that changes nothing (though I wish GitHub had moved-block detection support like WinMerge, which would obviously make this easier - but as it's a commercial Microsoft product and we are not paying customers, I doubt we will ever get any movement there with a feature request). I think this may be a reasonable approach towards making #994 more achievable, or even figuring out how it would be achieved. |
Or which tests already should belong elsewhere. |
Hey @oliverklee, I was having an issue with the second bug reported above ( I reported it to the Symfony team and it's been fixed in all supported Symfony branches. Just to let you know you can remove it from from your issue list 🙂 |
@nlemoine Thanks! |
The first was discovered by another test class more by chance, and (I think) should be tested specfically by
CssInlinerTest
. The second was reported against Symfony.[href=https://example.org]
#test\:colon
The text was updated successfully, but these errors were encountered: