E2E Tests
The Tableau MCP project uses Vitest for end-to-end (E2E) testing. E2E tests are located in
the tests/e2e directory and are named *.test.ts.
Running
The E2E tests can only be run:
- As part of the CI pipeline.
- Locally if you have access to a site the tests understand. Currently, that's only https://10ax.online.tableau.com/#/site/mcp-test/.
To run them locally:
- Ensure you do not have a
.envfile in the root of the project. - Create a
tests/.envfile with contents:
SERVER=https://10ax.online.tableau.com
SITE_NAME=mcp-test
AUTH=direct-trust
JWT_SUB_CLAIM=<your email address>
CONNECTED_APP_CLIENT_ID=<redacted>
CONNECTED_APP_SECRET_ID=<redacted>
CONNECTED_APP_SECRET_VALUE=<redacted>
- Create a
tests/.env.resetfile with the same contents except all the env var values are empty. (Environment variables get set at the beginning of each test and cleared at the end of each test.) - Run
npm run test:e2eor select thevitest.config.e2e.tsconfig in the Vitest extension and run them from your IDE.
Running the E2E tests against a different site
To run the E2E tests locally against a different site, you need to:
- Have a site that has the Superstore sample datasource and workbook (which exist with every new site). The tests query this datasource and workbook.
- Create and enable a Direct Trust Connected App in the site.
- Create a Pulse Metric Definition named
Tableau MCP. Its details don't matter. - Update the
environmentDataobject intests/constants.tswith the new site details. - Follow the steps in the Running section, providing these new site details in the
tests/.envfile.
Debugging
If you are using VS Code or a fork, you can use the Vitest extension to run and debug the E2E tests.