Note This repository isn’t part of our core product, it's a part of our internal tools.
This repository contains mock server that is used for advanced E2E tests for our proxy integrations. When the integration is properly configured, it allows us to inspect requests sent from these integrations and perform necessary assertions.
In order to test your proxy integration, you need to configure it to send requests to this mock app.
In most cases, this can be done by setting these two ENV variables when building the integration: FPCDN and INGRESS_API. For example:
FPCDN=<API_URL> INGRESS_API=<API_URL> pnpm run buildYou also need to set secret as your proxy secret key.
Refer to specific integration README for more details.
Note In order to get the API URL, contact the DX team.
If you navigate to the mock app URL, you will see a simple UI that allows you to run the tests.

This app exposes REST API that can be used to run the tests.
To run tests, send a POST request to: /api/test/run-tests with the following payload:
{
  // Base origin of your proxy integration
  "integrationUrl": "https://mock-test-inter-568-mock-app-tests.cfi-fingerprint.com/worker/",
  // CDN path in your proxy integration
  "cdnPath": "pxdownload",
  // Ingress path in your proxy integration
  "ingressPath": "pxresult",
  // First part of ii parameter sent by our proxy integration: <trafficName>/<integrationVersion>/type
  "trafficName": "fingerprint-pro-akamai",
  // Second part of ii parameter sent by our proxy integration: <trafficName>/<integrationVersion>/type
  "integrationVersion": "1.0.1-snapshot.0",
  // Optional filters
  "include": ["ingress", "agent*", "/body integrity protected with \\d{3} status code$/i"],
  "exclude": ["query params", "ipv6"]
}You will receive following response:
{
  "host": "https://mock-test-inter-568-mock-app-tests.cfi-fingerprint.com",
  "status": "finished",
  "results": [
    {
      // True if the test passed
      "passed": true,
      // Name of the test
      "testName": "agent request query params",
      // Duration of the request in milliseconds
      "requestDurationMs": 322
    },
    {
      // False if the test failed
      "passed": false,
      // Name of the test
      "testName": "ingress request headers",
      // Duration of the request in milliseconds
      "requestDurationMs": 23,
      // Assertion that failed
      "reason": "customQuery",
      "meta": {
        "error": {
          "generatedMessage": false,
          "code": "ERR_ASSERTION",
          "actual": "123",
          "expected": "1234",
          "operator": "assert"
        },
        // Array of requests that we received from proxy for this test
        "requestsFromProxy": [
          {
            // URL from our app that proxy sent request to
            "url": "<MOCK_APP_HOST>/worker/pxresult",
            // Request headers
            "headers": {},
            // Request method
            "method": "POST"
          }
        ]
      }
    }
  ]
}As an alternative, you can use our CLI client:
pnpm dlx "git+https://github.com/fingerprintjs/dx-team-mock-for-proxy-integrations-e2e-tests.git" --
# URL of the mock server 
--api-url="<API_URL>" 
# Base URL of your integration
--integration-url="https://mock-test-inter-568-mock-app-tests.cfi-fingerprint.com/worker/"
# CDN path in your proxy integration 
--cdn-path="pxdownload"
# Ingress path in your proxy integration
--ingress-path="pxresult"
# First part of ii parameter sent by our proxy integration: <trafficName>/<integrationVersion>/type
--traffic-name="fingerprint-pro-akamai"
# Second part of ii parameter sent by our proxy integration: <trafficName>/<integrationVersion>/type
--integration-version="1.0.1-snapshot.0"
# (Optional) Include tests by case-insensitive substring matching (if omitted, all tests are included)
--include="agent request"
# (Optional) Glob-lite matching (* any sequence, ? any single char)
--include="agent*" # includes test cases that start with "agent"
--include="*status code" # includes tests that end with "status code"
# (Optional) RegEx literal: /pattern/flags
--include="/body integrity protected with \d{3} status code$/i"
# (Optional) Exclude tests (same matching rules as include)
--exclude="ipv6"Test cases can be found in src/app/test/cases directory, and look like this:
import { assert, assertToBeTruthy } from '../../service/assert'
import { TestCase } from '../../types/testCase'
const testCase: TestCase = {
  // Name of the tests
  name: 'agent request preserve header and query',
  // Test function. It receives `api` object that can be used to send requests to the proxy integration.
  test: async (api) => {
    const query = new URLSearchParams()
    query.set('customQuery', '123')
    // `requestFromProxy` is the request that we received from proxy integration.
    const { requestFromProxy } = await api
      // or .sendRequestToIngress which sends request to the ingress endpoint
      // or .sendRequestToCacheEndpoint which sends request to the cache endpoint
      .sendRequestToCdn(query, { headers: { 'X-Custom': '123' } })
    const { ii, customQuery } = requestFromProxy.query
    assertToBeTruthy(ii)
    assertToBeTruthy(customQuery)
    // More assertions
  },
}
export default testCaseTo add new test case, simply create new file in src/app/test/cases directory with *.case.ts file name and provide default export with the TestCase object.
It will be automatically picked up by the test runner.
- Clone the repository.
- Install dependencies: pnpm install.
- Run the app: pnpm run start:dev. By default the app will run on port3000.
- Use a tunnel to make the app accessible from the internet. For example, you can use ngrok:
ngrok http 3000 
- Use the URL provided by ngrok to run the tests. Refer to the Preperation section for more details.
To run this project using Docker Compose, follow these steps:
- 
Set up Ngrok Authentication - Visit https://dashboard.ngrok.com/get-started/your-authtoken
- Click the "Copy" button to copy your Ngrok auth token
- Create a .envfile in the project root if it doesn't exist
- Add or update the NGROK_AUTH_TOKEN in the .envfile:NGROK_AUTH_TOKEN=your_copied_auth_token
 
- 
Run Docker Compose - Open a terminal in the project root directory
- Run the following command to start the containers in detached mode:
docker compose up -d --build
- This will build the Docker image and start the containers for both the application and Ngrok in the background
 
- 
Access the Ngrok Tunnel - Once the containers are running, visit https://dashboard.ngrok.com/endpoints
- You should see your active tunnel listed here, sorted by creation time (most recent first)
- Use the provided Ngrok URL to access your application through the secure tunnel
 
- 
Viewing Logs - If you need to view the logs while the containers are running in detached mode, use:
docker compose logs -f
- This will display the logs and follow them in real-time. Use Ctrl+C to exit the log view.
 
- If you need to view the logs while the containers are running in detached mode, use:
- 
Updating the Application - If you make changes to the code, the hot module reload may not be sufficient. In such cases, you need to restart the app service using the following command:
docker compose up -d --build app
- This command will rebuild the app service with your changes and restart it, without affecting the ngrok service
 
- If you make changes to the code, the hot module reload may not be sufficient. In such cases, you need to restart the app service using the following command: