This directory contains all testsuites for all CSS specifications still using the CSS test harness. These should primarily be considered legacy; new testsuites should almost always be put at the top level without any level suffix.
As the test harness relies on the largely undocumented(!) old CSS build system, this directory has a number of test requirements specific to it:
-
support files for a given test must live in an adjacent
support
directory; -
tests must have a
<link rel=help>
pointing to what they are testing; -
for each spec so linked, test filenames must be unique; and
-
support and reference files must have unique filenames within the entire
css
directory.
There are a few special directories that do not map to specifications:
vendor-imports/ is a legacy directory where third parties historically imported their tests that originate and are maintained in an external repo. Files in this directory should never be modified in this repo, but should go through the vendor's process to be imported here.
work-in-progress/ is a legacy directory that contains all the work that was once submitted to the repo, but was not yet ready for review. As pull requests are now used, no new files should be added here. The subdirectories here are named by test author or contributing organization.
Given an old branch in git based against the old csswg-test repository, it can be moved over to the merged repo in one of two ways:
-
(Recommended:) Rebasing on top of web-platform-tests: with the old branch checked out, run
git rebase -Xsubtree=css/ origin/master
(or similar, depending on the name of the upstream remote). -
Merging to web-platform-tests: with web-platform-tests' master branch checked out, run
git merge -Xsubtree=css/ my_shiny_branch
(or similar, depending on the name of your branch).
If you have a branch/bookmark in Mercurial, the process is more complicated:
-
From the Mercurial repo, run
hg export --git -r 'outgoing()' > foo.patch
. This will export all the changeset shown inhg log -r 'outgoing()'
; it's recommended you check this is the right set of changesets before continuing! -
Move to the git repo, and create a new branch based on web-platform-tests' master; e.g.,
git checkout -b hg-import origin/master
(or similar, depending on the name of the upstream remote). -
Download hg-patch-to-git-patch and run
python2 hg-patch-to-git-patch < foo.patch > bar.patch
(wherefoo.patch
is the path to thefoo.patch
you exported above). -
Run
git am --directory=css/ < bar.patch
.