# testcafe-hammerhead `testcafe-hammerhead` is a powerful Web proxy used as a core for the [TestCafe](https://github.com/devexpress/testcafe) testing framework. ## Core Concepts `testcafe-hammerhead` is a URL-rewriting proxy. This means that it rewrites all properties of the appropriate JavaScript objects that contain a URL value (`Location`, `HTMLLinkElement.href`, etc). You can see it if you open a proxied page, invoke the browser's DevTools and inspect any element. In addition, the proxied web page does not know that it is opened under a proxy. The proxy intercepts access attempts to all URL-containing properties and provides the original values. ## First Look 1. Clone the Hammerhead repository ```cmd git clone https://github.com/DevExpress/testcafe-hammerhead.git ``` 1. Go to the `testcafe-hammerhead` folder ```cmd cd testcafe-hammerhead ``` 1. Install the dependencies ```cmd npm install ``` 1. Run the [Hammerhead playground](https://github.com/DevExpress/testcafe-hammerhead/blob/master/test/playground/server.js) to see our proxy in action ```cmd node node_modules/gulp/bin/gulp http-playground ``` This opens a playground page where you can specify a webpage to proxy. Enter the page URL and hit **Proxy!**. ## Features * HTTP/HTTPS requests * WebSockets, EventSource * file upload * request events (`onRequest`, `onResponse`) * bypassing requests * custom UI on a web page ## Reporting Issues and Contributing Read our [Contributing Guide](https://github.com/DevExpress/testcafe-hammerhead/blob/master/CONTRIBUTING.md) to learn how to contribute to the project. [data:image/s3,"s3://crabby-images/1df58/1df582039cfdcf5c28e9feeb8ef54f8e21631997" alt="Build Status"](https://github.com/DevExpress/testcafe-hammerhead/commits/master) [data:image/s3,"s3://crabby-images/1cc6b/1cc6bd2db29b7c0ac2d71db0df7dafb715fdb22f" alt="Sauce Test Status"](https://saucelabs.com/u/testcafebot) [data:image/s3,"s3://crabby-images/1dc42/1dc42e454cc02ac51ef41a42714d8f0e27c4f101" alt="Health Monitor"](http://20.124.101.246:13500/)