Validating and testing policies
| This documentation is for a previous version of Cerbos. Choose 0.46.0 from the version picker at the top right or navigate to https://docs.cerbos.dev for the latest version. | 
Validating policies
You can use the Cerbos compiler to make sure that your policies are valid before pushing them to a production Cerbos instance. We recommend setting up a git hook or a CI step to run the Cerbos compiler before you push any policy changes to production.
docker run -i -t -v /path/to/policy/dir:/policies ghcr.io/cerbos/cerbos:0.45.1 compile /policiesTesting policies
You can write optional tests for policies and run them as part of the compilation stage to make sure that the policies do exactly what you expect.
Tests are defined using the familiar YAML format as well. A test file must have _test suffix in the name and one of the following file extensions: yaml, yml, or json. For example, album_test.yml, album_test.yaml or album_test.json.
---
name: AlbumObjectTestSuite (1)
description: Tests for verifying the album:object resource policy (2)
options:
  now: "2022-08-02T15:00:00Z" (3)
  defaultPolicyVersion: staging (4)
  lenientScopeSearch: true (5)
  globals: (6)
    my_global_var: foo
principals: (7)
  alicia:
    id: aliciaID
    roles:
      - user
  bradley:
    id: bradleyID
    roles:
      - user
principalGroups: (8)
  everyone:
    principals:
      - alicia
      - bradley
resources: (9)
  alicia_album:
    id: XX125
    kind: album:object
    policyVersion: default
    attr:
      owner: aliciaID
      public: false
      flagged: false
  bradley_album:
    id: XX250
    kind: album:object
    policyVersion: staging
    attr:
      owner: bradleyID
      public: false
      flagged: false
resourceGroups: (10)
  all_albums:
    resources:
      - alicia_album
      - bradley_album
auxData: (11)
  validJWT:
    jwt:
      iss: my.domain
      aud: ["x", "y"]
      myField: value
tests: (12)
  - name: Accessing an album (13)
    options: (14)
      now: "2022-08-03T15:00:00Z" (15)
      defaultPolicyVersion: production (16)
      lenientScopeSearch: false (17)
      globals: (18)
        my_global_var: bar
    input: (19)
      principals: (20)
        - alicia
        - bradley
      resources: (21)
        - alicia_album
        - bradley_album
      actions: (22)
        - view
        - delete
      auxData: validJWT (23)
    expected: (24)
      - principal: alicia (25)
        resource: alicia_album (26)
        actions: (27)
          view: EFFECT_ALLOW
          delete: EFFECT_ALLOW
        outputs: (28)
          - action: view (29)
            expected: (30)
              - src: resource.album.vdefault#view-rule
                val:
                  key1: value1
                  key2: ["value2", "value3"]
              - src: resource.album.vdefault#token-lifetime
                val: 1h
      - principal: bradley
        resource: bradley_album
        actions:
          view: EFFECT_ALLOW
          delete: EFFECT_ALLOW
  - name: Using groups
    input:
      principalGroups: (31)
        - everyone
      resourceGroups: (32)
        - all_albums
      actions:
        - download
    expected:
      - principalGroups: (33)
          - everyone
        resourceGroups: (34)
          - all_albums
        actions:
          download: EFFECT_DENY| 1 | Name of the test suite | 
| 2 | Description of the test suite | 
| 3 | Optional RFC3339 timestamp to be used as the return value of the nowfunction. Applies to all tests in the suite unless overridden locally. | 
| 4 | Optionally set default policy version for this test suite | 
| 5 | Optionally set lenient scope search for this test suite | 
| 6 | Optionally set globals for this test suite | 
| 7 | Map of principal fixtures. The key is a string that can be used to refer to the associated principal. | 
| 8 | Map of principal groups. The key is a string that can be used to refer to the associated group of principal fixtures. | 
| 9 | Map of resource fixtures. The key is a string that can be used to refer to the associated resource. | 
| 10 | Map of resource groups. The key is a string that can be used to refer to the associated group of resource fixtures. | 
| 11 | Map of (optional) auxiliary data fixtures required to evaluate some requests. The key is a string that can be used to refer to the associated auxData. | 
| 12 | List of tests in this suite | 
| 13 | Name of the test | 
| 14 | Optionally set options that apply to just this test. Test-specific options are not merged with suite-wide options, so any unspecified values revert to the default. | 
| 15 | Optional RFC3339 timestamp to be used as the return value of the nowfunction. | 
| 16 | Optionally set default policy version for this test. | 
| 17 | Optionally set lenient scope search for this test. | 
| 18 | Optionally set globals for this test. | 
| 19 | Input to the policy engine | 
| 20 | List of keys of principal fixtures to test | 
| 21 | List of keys of resource fixtures to test | 
| 22 | List of actions to test | 
| 23 | Key of auxiliary data fixture to test (optional) | 
| 24 | List of outcomes expected for each principal and resource. If a principal+resource pair specified in inputis not listed inexpected, thenEFFECT_DENYis expected for all actions for that pair. | 
| 25 | Key of the principal fixture under test. Use principalsinstead ofprincipalif you want to specify identical expectations for multiple principals. | 
| 26 | Key of the resource fixture under test. Use resourcesinstead ofresourceif you want to specify identical expectations for multiple resources. | 
| 27 | Expected outcomes for each action for each principal+resource pair. If an action specified in inputis not listed, thenEFFECT_DENYis expected for that action. | 
| 28 | Optional list of output values to match | 
| 29 | Name of the action that would produce the output | 
| 30 | List of expected output values | 
| 31 | List of keys of principal groups to test. You can provide this instead of, or as well as, principals. | 
| 32 | List of keys of resource groups to test. You can provide this instead of, or as well as, resources. | 
| 33 | Key of the principal group under test. You can provide this instead of, or as well as, principalorprincipals. | 
| 34 | Key of the resource group under test. You can provide this instead of, or as well as, resourceorresources. | 
Sharing test fixtures
It is possible to share principals, resources and auxData blocks between test suites stored in the same directory. Create a testdata directory in the directory containing your test suite files, then define shared resources, principals and auxData in testdata/resources.yml, testdata/principals.yml, testdata/auxdata.yml respectively (yaml and json extensions are also supported).
tests ├── album_object_test.yaml ├── gallery_object_test.yaml ├── slideshow_object_test.yaml └── testdata ├── auxdata.yaml ├── principals.yaml └── resources.yaml
testdata/principals.yml---
principals: # required
  john:
    id: johnID
    roles:
      - user
      - moderator
principalGroups: # optional
  moderators:
    principals:
      - johntestdata/resources.yml---
resources: # required
  alicia_album:
    id: XX125
    kind: "album:object"
    attr:
      owner: aliciaID
      public: false
      flagged: false
resourceGroups: # optional
  all_albums:
    resources:
      - alicia_albumtestdata/auxdata.yml---
auxData: # required
  validJWT:
    jwt:
      iss: my.domain
      aud: ["x", "y"]
      myField: value| YAML anchors and overrides are a great way to reduce repetition and reuse definitions in test cases. For example, the following definitions are equivalent: 
 | 
Running tests
The compile command automatically discovers test files in the policy repository.
docker run -i -t \
    -v /path/to/policy/dir:/policies \
    ghcr.io/cerbos/cerbos:0.45.1 compile /policiesThe output format can be controlled using the --output flag, which accepts the values tree (default), list and json. The --color flag controls the coloring of the output. To produce machine readable output from the tests, pass --output=json --color=never to the command.
By default, all discovered tests are run. Use the --skip-tests flag to skip all tests or use the --run flag to run a set of tests that match a regular expression.
docker run -i -t \
    -v /path/to/policy/dir:/policies \
    ghcr.io/cerbos/cerbos:0.45.1 compile --run=Delete /policiesYou can mark entire suites or individual tests in a suite with skip: true to skip them during test runs.
---
name: AlbumObjectTestSuite
description: Tests for verifying the album:object resource policy
tests:
  - name: View private album
    skip: true
    skipReason: "Policy under review"
    input:
      principals: ["alicia"]
      resources: ["alicia_private_album"]
      actions: ["view"]
    expected:
      - principal: alicia
        resource: alicia_private_album
        actions:
          view: EFFECT_ALLOWValidating and testing policies in CI environments
Because Cerbos artefacts are distributed as self-contained containers and binaries, you should be able to easily integrate Cerbos into any CI environment. Simply configure your workflow to execute the commands described in the sections above using either the Cerbos container (you may need to configure mount points to suit your repo structure) or the binary.
GitHub Actions
- 
cerbos-setup-action: Install cerbosandcerbosctlbinaries into your workflow tools cache
- 
cerbos-compile-action: Compile and (optionally) test Cerbos policies 
---
name: PR Check
on:
  pull_request:
    branches:
      - main
jobs:
  cerbosCheck:
    name: Check Cerbos policies
    runs-on: ubuntu-latest
    steps:
      - name: Checkout code
        uses: actions/checkout@v2
      - name: Setup Cerbos
        uses: cerbos/cerbos-setup-action@v1
        with:
          version: latest
      - name: Compile and test policies
        uses: cerbos/cerbos-compile-action@v1
        with:
          policyDir: policiesSee https://github.com/cerbos/photo-share-tutorial for an example of Cerbos GitHub Actions being used in a workflow.
GitLab CI
---
stages:
  - prepare
  - compile
download-cerbos:
  stage: prepare
  script:
    - curl https://github.com/cerbos/cerbos/releases/download/v0.45.1/cerbos_0.45.1_Linux_x86_64.tar.gz -L --output /tmp/cerbos.tar.gz
    - tar -xf /tmp/cerbos.tar.gz -C ./
    - chmod +x ./cerbos
  artifacts:
    paths:
      - cerbos
compile-job:
  stage: compile
  dependencies: ["download-cerbos"]
  script:
    - ./cerbos compile ./policiesDagger
The Dagger Cerbos module can be installed by running dagger install github.com/cerbos/dagger-cerbos. This module provides a compile function for compiling and testing Cerbos policy repositories and a server service for starting a Cerbos server.
# Compile and run tests on a policy repository
dagger -m github.com/cerbos/dagger-cerbos call compile --policy-dir=./cerbos
# Start a Cerbos server with the default disk driver
dagger -m github.com/cerbos/dagger-cerbos call server --policy-dir=./cerbos up
# Start a Cerbos server instance configured to use an in-memory SQLite policy repository
dagger -m github.com/cerbos/dagger-cerbos call server --config=storage.driver=sqlite3,storage.sqlite3.dsn=:memory:,server.adminAPI.enabled=true up
# View usage information
dagger -m github.com/cerbos/dagger-cerbos call compile --help
dagger -m github.com/cerbos/dagger-cerbos call server --help