Skip to content
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

HTML API: CSS matching #11

Draft
wants to merge 116 commits into
base: trunk
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
116 commits
Select commit Hold shift + click to select a range
6383964
I18N: Load admin translations for auto update emails.
swissspidy Dec 2, 2024
daad863
Plugins: Make more plugin-related functions available early on.
swissspidy Dec 2, 2024
d93b275
Customize: Begin HTML markup before Customizer script hooks.
SergeyBiryukov Dec 2, 2024
8eb8d63
External Libraries: Upgrade PHPMailer to version 6.9.3.
SergeyBiryukov Dec 3, 2024
1d49212
Block Hooks: Fix context in `update_ignored_hooked_blocks_postmeta`.
ockham Dec 4, 2024
d576e24
Build/Test Tools: Add `repository` input to support JSON reading work…
desrosj Dec 4, 2024
ea80ac8
Build/Test Tools: Support older MariaDB versions in local Docker envi…
desrosj Dec 4, 2024
9558c1f
Build/Test Tools: Run install tests when JSON reading workflow is cha…
desrosj Dec 4, 2024
7d3ce7a
Docs: Remove blank line at the end of `wp_prepare_attachment_for_js()…
SergeyBiryukov Dec 4, 2024
b67c76e
Plugins: Load `wp-admin/includes/plugin.php` earlier.
swissspidy Dec 5, 2024
e585c95
Build/Test Tools: Properly escape `$` characters in Docker compose file.
desrosj Dec 5, 2024
5adbb3e
Build/Test Tools: Use newer versions for `include` jobs.
desrosj Dec 5, 2024
2d8d21f
Build/Test Tools: Support `trunk` as a version.
desrosj Dec 5, 2024
29ec312
Build/Test Tools: Introduce workflow for testing the local Docker env…
desrosj Dec 5, 2024
9c7d008
Embeds: ensure correct thumbnail height.
swissspidy Dec 5, 2024
59a6b5e
I18N: Add new `WP_Locale::get_month_genitive()` method.
swissspidy Dec 5, 2024
0e8c4fb
WIP class skeleton
sirreal Nov 19, 2024
2d3d283
Document class
sirreal Nov 20, 2024
40222d3
Do not support namespaced selectors
sirreal Nov 21, 2024
6092642
Flesh out stuff
sirreal Nov 22, 2024
3e3b2b2
Starting to actually parse
sirreal Nov 22, 2024
967557f
Add ident tests
sirreal Nov 22, 2024
2ec1db3
Fix ident non-ascii bug
sirreal Nov 22, 2024
ee2c7ce
Use class after defined
sirreal Nov 22, 2024
0f708ba
Fix some char stuff
sirreal Nov 22, 2024
3cb455d
Improve tests
sirreal Nov 22, 2024
5609e50
Housekeeping
sirreal Nov 22, 2024
4f25bc2
Require new file in WP
sirreal Nov 22, 2024
943293f
Fix offset type
sirreal Nov 22, 2024
24c9744
Add more tests and invalid tests
sirreal Nov 22, 2024
a7c10b9
Fix wrong offset var usage
sirreal Nov 22, 2024
dd718b7
comment tweak
sirreal Nov 22, 2024
5884aca
Implement codepoint escape with strspn
sirreal Nov 22, 2024
a9a077f
Test with UPPER HEX
sirreal Nov 22, 2024
5f53e0a
Add ID tests
sirreal Nov 25, 2024
effbbbe
Improve tests
sirreal Nov 25, 2024
62ec5bb
Add class selector tests
sirreal Nov 25, 2024
153f009
Add class selector
sirreal Nov 25, 2024
fcc6401
Simplify id selector parse
sirreal Nov 25, 2024
21c67e5
Improve ident tests
sirreal Nov 25, 2024
728d798
Add type selector tests
sirreal Nov 25, 2024
e1e8e09
Add docs and remove unreachable line
sirreal Nov 25, 2024
13ac3c1
Add type selector class
sirreal Nov 25, 2024
a3c25e8
Add attribute selector tests
sirreal Nov 25, 2024
ad5c600
improve attr tests
sirreal Nov 25, 2024
6758704
Fix expectation argument order
sirreal Nov 25, 2024
e97842c
Add test and fix is_ident
sirreal Nov 25, 2024
ef00856
Add parse_string stub
sirreal Nov 26, 2024
463e799
Add attribute selector parsing
sirreal Nov 26, 2024
0f5b28c
Fix test expectations
sirreal Nov 26, 2024
f4a491a
More and improved attribute tests
sirreal Nov 26, 2024
b680b1b
Implement parse_string
sirreal Nov 26, 2024
e7da05f
Add string parse tests
sirreal Nov 26, 2024
d5e7e60
Remove covers annotations
sirreal Nov 26, 2024
08187c6
Remove unused line
sirreal Nov 26, 2024
5a5066c
Improve tests for 100% coverage on parse methods
sirreal Nov 26, 2024
2f8bd19
Improve documentation
sirreal Nov 26, 2024
8b0ac55
Fix parse return type and return annotations
sirreal Nov 26, 2024
dffcac6
Update documentation links and grammar
sirreal Nov 27, 2024
9f81744
Update documentation and class name
sirreal Nov 27, 2024
d4c6f38
Add selector class
sirreal Nov 27, 2024
6432056
Implement complex selector
sirreal Nov 27, 2024
5c746cd
Working and tested
sirreal Nov 27, 2024
501102a
Selector parsing should allow cap I,S modifier
sirreal Nov 28, 2024
f98fbb3
CSS Add matches to selector classes
sirreal Nov 28, 2024
c8f16e1
Match is successful on _any_ match in selector list
sirreal Nov 28, 2024
c689c9c
PICKME: Add is_quirks_mode method to processor
sirreal Nov 28, 2024
1221efa
ID matches depend on quirks mode
sirreal Nov 28, 2024
e5e94b1
has_class may return null, coerce to bool
sirreal Nov 28, 2024
1e888ba
Update docs to only allow subclass selectors in final complex selecto…
sirreal Nov 28, 2024
dd4fcb0
Restrict complex selectors to only allow subclass selectors in final …
sirreal Nov 28, 2024
256c55a
Work on complex selector handling
sirreal Nov 28, 2024
465cc36
Implement descendent selector matching
sirreal Nov 28, 2024
467d45d
Add null check for subclass selectors
sirreal Nov 29, 2024
44bfc64
CSS selector reformat ternaries
sirreal Nov 29, 2024
ca4531c
Implement ~= attribute matching
sirreal Nov 29, 2024
489db93
CSS fix return type
sirreal Nov 29, 2024
e57a211
Fix static analysis problems
sirreal Nov 29, 2024
509e648
Fix and annotate things (static analysis)
sirreal Nov 29, 2024
58c1698
update tests
sirreal Nov 29, 2024
c9b9145
Id attribute must be a string to match id selector
sirreal Nov 29, 2024
e5cac63
Coerce boolean attributes to ""
sirreal Nov 29, 2024
2bafae9
Fix a few more static analysis things
sirreal Nov 29, 2024
8fe57e3
Add select method
sirreal Nov 28, 2024
ab2fe0d
Unify parsing under single class
sirreal Dec 3, 2024
6a6969f
Rename files to align with class name
sirreal Dec 3, 2024
27ca891
Add html processor select test suite
sirreal Dec 3, 2024
9ff2769
Fix select types
sirreal Dec 3, 2024
d1a276b
Update class doc
sirreal Dec 4, 2024
4909b56
Improve select_ method arguments, docs, implementation
sirreal Dec 4, 2024
1d45225
Split classes into their own files
sirreal Dec 4, 2024
0b277b4
Remove redundant see phpdoc annotations
sirreal Dec 4, 2024
0c53c42
Fix docs and return type on select_all
sirreal Dec 4, 2024
d966e9a
Improve html select test docs
sirreal Dec 4, 2024
5201ba9
Add select support to tag processor
sirreal Dec 4, 2024
2036a83
Simplify whitspace splitting function
sirreal Dec 4, 2024
3421a4e
Remove unreachable code
sirreal Dec 4, 2024
784b2d9
Add a lot of selector integration tests
sirreal Dec 4, 2024
4d4c5fe
Extract normalize input method
sirreal Dec 4, 2024
dbc37fc
tests
sirreal Dec 4, 2024
d241f31
Add nonfinal subclass selector test
sirreal Dec 4, 2024
663070b
Fix logic bug in child selector exploration
sirreal Dec 5, 2024
5478af9
Improve selector integration tests
sirreal Dec 5, 2024
4f6bf94
Try abstract class instead of interface
sirreal Dec 5, 2024
fe07dfd
Revert "Try abstract class instead of interface"
sirreal Dec 5, 2024
143e092
Clean up and document attribute selector
sirreal Dec 5, 2024
32ee2a7
Update ticket number in tests
sirreal Dec 5, 2024
5922494
Improve some types
sirreal Dec 5, 2024
e492aa6
Fix and improve string token parsing
sirreal Dec 5, 2024
81c6758
Update attribute selector tests
sirreal Dec 5, 2024
7bccf3e
Revert "Update attribute selector tests"
sirreal Dec 5, 2024
3949cc5
Improve some complex selector match tests
sirreal Dec 5, 2024
8f2a2ca
Merge branch 'html-api/add-css-selector-parser' into html-api/work-on…
sirreal Nov 28, 2024
cf6ffef
DROPME: phpstan setup
sirreal Nov 29, 2024
9782e10
Max phpstan level
sirreal Nov 29, 2024
f38704e
DROPME: ignore code coverage HTML API
sirreal Dec 4, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions .github/workflows/install-testing.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ on:
paths:
- '.github/workflows/install-testing.yml'
- '.version-support-*.json'
- '.github/workflows/reusable-support-json-reader-v1.yml'
pull_request:
# Always test the workflow when changes are suggested.
paths:
Expand Down
154 changes: 154 additions & 0 deletions .github/workflows/local-docker-environment.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,154 @@
name: Local Docker Environment

on:
push:
branches:
- trunk
- '6.[8-9]'
- '[7-9].[0-9]'
paths:
# Any changes to Docker related files.
- '.env.example'
- 'docker-compose.yml'
# Any changes to local environment related files
- 'tools/local-env/**'
# These files manage packages used by the local environment.
- 'package*.json'
# These files configure Composer. Changes could affect the local environment.
- 'composer.*'
# These files define the versions to test.
- '.version-support-*.json'
# Changes to this and related workflow files should always be verified.
- '.github/workflows/local-docker-environment.yml'
- '.github/workflows/reusable-support-json-reader-v1.yml'
- '.github/workflows/reusable-test-docker-environment-v1.yml'
pull_request:
branches:
- trunk
- '6.[8-9]'
- '[7-9].[0-9]'
paths:
# Any changes to Docker related files.
- '.env.example'
- 'docker-compose.yml'
# Any changes to local environment related files
- 'tools/local-env/**'
# These files manage packages used by the local environment.
- 'package*.json'
# These files configure Composer. Changes could affect the local environment.
- 'composer.*'
# These files define the versions to test.
- '.version-support-*.json'
# Changes to this and related workflow files should always be verified.
- '.github/workflows/local-docker-environment.yml'
- '.github/workflows/reusable-support-json-reader-v1.yml'
- '.github/workflows/reusable-test-docker-environment-v1.yml'
workflow_dispatch:

# Cancels all previous workflow runs for pull requests that have not completed.
concurrency:
# The concurrency group contains the workflow name and the branch name for pull requests
# or the commit hash for any other events.
group: ${{ github.workflow }}-${{ github.event_name == 'pull_request' && github.head_ref || github.sha }}
cancel-in-progress: true

# Disable permissions for all available scopes by default.
# Any needed permissions should be configured at the job level.
permissions: {}

jobs:
#
# Determines the appropriate supported values for PHP and database versions based on the WordPress
# version being tested.
#
build-test-matrix:
name: Build Test Matrix
uses: WordPress/wordpress-develop/.github/workflows/reusable-support-json-reader-v1.yml@trunk
permissions:
contents: read
secrets: inherit
if: ${{ github.repository == 'WordPress/wordpress-develop' || github.event_name == 'pull_request' }}
with:
wp-version: ${{ github.event_name == 'pull_request' && github.base_ref || github.ref_name }}

# Tests the local Docker environment.
environment-tests-mysql:
name: PHP ${{ matrix.php }}
uses: WordPress/wordpress-develop/.github/workflows/reusable-test-local-docker-environment-v1.yml@trunk
permissions:
contents: read
if: ${{ github.repository == 'WordPress/wordpress-develop' || github.event_name == 'pull_request' }}
needs: [ build-test-matrix ]
strategy:
fail-fast: false
matrix:
os: [ ubuntu-latest ]
memcached: [ false, true ]
php: ${{ fromJSON( needs.build-test-matrix.outputs.php-versions ) }}
db-version: ${{ fromJSON( needs.build-test-matrix.outputs.mysql-versions ) }}

exclude:
# The MySQL 5.5 containers will not start.
- db-version: '5.5'
# MySQL 9.0+ will not work on PHP 7.2 & 7.3
- php: '7.2'
db-version: '9.0'
- php: '7.3'
db-version: '9.0'

with:
os: ${{ matrix.os }}
php: ${{ matrix.php }}
db-type: 'mysql'
db-version: ${{ matrix.db-version }}
memcached: ${{ matrix.memcached }}
tests-domain: ${{ matrix.tests-domain }}

slack-notifications:
name: Slack Notifications
uses: WordPress/wordpress-develop/.github/workflows/slack-notifications.yml@trunk
permissions:
actions: read
contents: read
needs: [ build-test-matrix, environment-tests-mysql ]
if: ${{ github.repository == 'WordPress/wordpress-develop' && github.event_name != 'pull_request' && always() }}
with:
calling_status: ${{ contains( needs.*.result, 'cancelled' ) && 'cancelled' || contains( needs.*.result, 'failure' ) && 'failure' || 'success' }}
secrets:
SLACK_GHA_SUCCESS_WEBHOOK: ${{ secrets.SLACK_GHA_SUCCESS_WEBHOOK }}
SLACK_GHA_CANCELLED_WEBHOOK: ${{ secrets.SLACK_GHA_CANCELLED_WEBHOOK }}
SLACK_GHA_FIXED_WEBHOOK: ${{ secrets.SLACK_GHA_FIXED_WEBHOOK }}
SLACK_GHA_FAILURE_WEBHOOK: ${{ secrets.SLACK_GHA_FAILURE_WEBHOOK }}

failed-workflow:
name: Failed workflow tasks
runs-on: ubuntu-latest
permissions:
actions: write
needs: [ build-test-matrix, environment-tests-mysql, slack-notifications ]
if: |
always() &&
github.repository == 'WordPress/wordpress-develop' &&
github.event_name != 'pull_request' &&
github.run_attempt < 2 &&
(
contains( needs.*.result, 'cancelled' ) ||
contains( needs.*.result, 'failure' )
)

steps:
- name: Dispatch workflow run
uses: actions/github-script@60a0d83039c74a4aee543508d2ffcb1c3799cdea # v7.0.1
with:
retries: 2
retry-exempt-status-codes: 418
script: |
github.rest.actions.createWorkflowDispatch({
owner: context.repo.owner,
repo: context.repo.repo,
workflow_id: 'failed-workflow.yml',
ref: 'trunk',
inputs: {
run_id: '${{ github.run_id }}'
}
});
26 changes: 13 additions & 13 deletions .github/workflows/phpunit-tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -53,40 +53,40 @@ jobs:
memcached: [ false ]

include:
# Include jobs for PHP 7.4 with memcached.
# Include jobs that test with memcached.
- os: ubuntu-latest
php: '7.4'
php: '8.3'
db-type: 'mysql'
db-version: '5.7'
db-version: '8.4'
tests-domain: 'example.org'
multisite: false
memcached: true
- os: ubuntu-latest
php: '7.4'
php: '8.3'
db-type: 'mysql'
db-version: '5.7'
db-version: '8.4'
tests-domain: 'example.org'
multisite: true
memcached: true
# Include jobs with a port on the test domain for both single and multisite.
- os: ubuntu-latest
php: '7.4'
php: '8.4'
db-type: 'mysql'
db-version: '5.7'
db-version: '8.4'
tests-domain: 'example.org:8889'
multisite: false
memcached: false
- os: ubuntu-latest
php: '7.4'
php: '8.4'
db-type: 'mysql'
db-version: '5.7'
db-version: '8.4'
tests-domain: 'example.org:8889'
multisite: true
memcached: false
# Report test results to the Host Test Results.
- os: ubuntu-latest
db-type: 'mysql'
db-version: '8.0'
db-version: '8.4'
tests-domain: 'example.org'
multisite: false
memcached: false
Expand Down Expand Up @@ -131,15 +131,15 @@ jobs:
memcached: [ false ]

include:
# Include jobs for PHP 7.4 with memcached.
# Include jobs that test with memcached.
- os: ubuntu-latest
php: '7.4'
php: '8.3'
db-type: 'mariadb'
db-version: '11.2'
multisite: false
memcached: true
- os: ubuntu-latest
php: '7.4'
php: '8.3'
db-type: 'mariadb'
db-version: '11.2'
multisite: true
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/reusable-phpunit-tests-v3.yml
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,7 @@ jobs:

- name: WordPress Docker container debug information
run: |
docker compose run --rm mysql ${{ env.LOCAL_DB_TYPE }} --version
docker compose run --rm mysql ${{ env.LOCAL_DB_TYPE == 'mariadb' && contains( fromJSON('["5.5", "10.0", "10.1", "10.2", "10.3"]'), env.LOCAL_DB_VERSION ) && 'mysql' || env.LOCAL_DB_TYPE }} --version
docker compose run --rm php php --version
docker compose run --rm php php -m
docker compose run --rm php php -i
Expand Down
11 changes: 9 additions & 2 deletions .github/workflows/reusable-support-json-reader-v1.yml
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,10 @@ on:
description: 'The WordPress version to test . Accepts major and minor versions, "latest", or "nightly". Major releases must not end with ".0".'
type: string
default: 'nightly'
repository:
description: 'The repository to read support JSON files from.'
type: string
default: 'WordPress/wordpress-develop'
outputs:
major-wp-version:
description: "The major WordPress version based on the version provided in wp-version"
Expand Down Expand Up @@ -42,14 +46,15 @@ jobs:
- name: Checkout repository
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
repository: ${{ inputs.repository }}
show-progress: ${{ runner.debug == '1' && 'true' || 'false' }}

- name: Determine the major WordPress version
id: major-wp-version
run: |
if [ "${{ inputs.wp-version }}" ] && [ "${{ inputs.wp-version }}" != "nightly" ] && [ "${{ inputs.wp-version }}" != "latest" ]; then
if [ "${{ inputs.wp-version }}" ] && [ "${{ inputs.wp-version }}" != "nightly" ] && [ "${{ inputs.wp-version }}" != "latest" ] && [ "${{ inputs.wp-version }}" != "trunk" ]; then
echo "version=$(echo "${{ inputs.wp-version }}" | tr '.' '-' | cut -d '-' -f1-2)" >> $GITHUB_OUTPUT
elif [ "${{ inputs.wp-version }}" ]; then
elif [ "${{ inputs.wp-version }}" ] && [ "${{ inputs.wp-version }}" != "trunk" ]; then
echo "version=$(echo "${{ inputs.wp-version }}")" >> $GITHUB_OUTPUT
else
echo "version=nightly" >> $GITHUB_OUTPUT
Expand All @@ -74,6 +79,7 @@ jobs:
- name: Checkout repository
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
repository: ${{ inputs.repository }}
show-progress: ${{ runner.debug == '1' && 'true' || 'false' }}

# Look up the major version's specific PHP support policy when a version is provided.
Expand Down Expand Up @@ -106,6 +112,7 @@ jobs:
- name: Checkout repository
uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 # v4.2.2
with:
repository: ${{ inputs.repository }}
show-progress: ${{ runner.debug == '1' && 'true' || 'false' }}

# Look up the major version's specific MySQL support policy when a version is provided.
Expand Down
Loading
Loading