[data:image/s3,"s3://crabby-images/77704/777049ce6209e2fc2eed5a64851ecba0303bc26e" alt="test-go"](https://github.com/cucumber/tag-expressions/actions/workflows/test-go.yml) [data:image/s3,"s3://crabby-images/ebfcc/ebfccee16467ff5cac222956bb4bc3cda2181508" alt="test-java"](https://github.com/cucumber/tag-expressions/actions/workflows/test-java.yml) [data:image/s3,"s3://crabby-images/a8866/a8866b1e4867ad5d581146b1cee1cd47bbcc9410" alt="test-javascript"](https://github.com/cucumber/tag-expressions/actions/workflows/test-javascript.yml) [data:image/s3,"s3://crabby-images/20bb2/20bb2bbe5a598258db34233e3657648b6ab40700" alt="test-perl"](https://github.com/cucumber/tag-expressions/actions/workflows/test-perl.yml) [data:image/s3,"s3://crabby-images/fa63f/fa63fa21ae8fc3935f941bd2ff168dccdec355a5" alt="test-python"](https://github.com/cucumber/tag-expressions/actions/workflows/test-python.yml) [data:image/s3,"s3://crabby-images/1d4b4/1d4b4ac764d2f66514a1b10c0403b748d67aa17f" alt="test-ruby"](https://github.com/cucumber/tag-expressions/actions/workflows/test-ruby.yml) # Tag Expressions Tag Expressions is a simple query language for tags. The simplest tag expression is simply a single tag, for example: @smoke A slightly more elaborate expression may combine tags, for example: @smoke and not @ui Tag Expressions are used for two purposes: 1. Run a subset of scenarios (using the `--tags expression` option of the [command line](https://cucumber.io/docs/cucumber/api/#running-cucumber)) 2. Specify that a hook should only run for a subset of scenarios (using [conditional hooks](https://cucumber.io/docs/cucumber/api/#hooks)) Tag Expressions are [boolean expressions](https://en.wikipedia.org/wiki/Boolean_expression) of tags with the logical operators `and`, `or` and `not`. For more complex Tag Expressions you can use parenthesis for clarity, or to change operator precedence: (@smoke or @ui) and (not @slow) ## Escaping If you need to use one of the reserved characters `(`, `)`, `\` or ` ` (whitespace) in a tag, you can escape it with a `\`. Examples: | Gherkin Tag | Escaped Tag Expression | | ------------- | ---------------------- | | @x(y) | @x\\(y\\) | | @x\y | @x\\\\y | ## Migrating from old style tags Older versions of Cucumber used a different syntax for tags. The list below provides some examples illustrating how to migrate to tag expressions. | Old style command line | Cucumber Expressions style command line | | ----------------------------- | --------------------------------------- | | --tags @dev | --tags @dev | | --tags ~@dev | --tags "not @dev" | | --tags @foo,@bar | --tags "@foo or @bar" | | --tags @foo --tags @bar | --tags "@foo and bar" | | --tags ~@foo --tags @bar,@zap | --tags "not @foo and (@bar or @zap)" |