96c414d48b | ||
---|---|---|
.config | ||
.github/workflows | ||
Common | ||
Scripts | ||
Source | ||
Tests | ||
Tools | ||
docs | ||
.gitattributes | ||
.gitignore | ||
.travis.yml | ||
Coyote.sln | ||
History.md | ||
LICENSE | ||
NuGet.config | ||
README.md | ||
SECURITY.md | ||
global.json | ||
mkdocs-local.yml | ||
mkdocs.yml |
README.md
Coyote is a .NET library and tool designed to help ensure that your code is free of concurrency bugs.
It gives you the ability to reliably unit test the concurrency and other sources of nondeterminism (such as message re-orderings, timeouts and failures) in your C# code. In the heart of Coyote is a scheduler that takes control (via binary rewriting) of your program's execution during testing and is able to systematically explore the concurrency and nondeterminism to find safety and liveness bugs. The awesome thing is that once Coyote finds a bug it gives you the ability to fully reproduce it as many times as you want, making debugging and fixing the issue much easier.
Coyote is used by several teams in Azure to systematically test their distributed systems and services, finding hundreds of bugs before they manifest in production. In the words of an Azure service architect:
Coyote found several issues early in the dev process, this sort of issues that would usually bleed through into production and become very expensive to fix later.
See our documentation for more information about the project, case studies, tutorials and reference documentation.
Coyote is made with ❤️ by Microsoft Research.
Contributing
This project welcomes contributions and suggestions. Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.opensource.microsoft.com.
When you submit a pull request, a CLA bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., status check, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repositories using our CLA.
Code of Conduct
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.