forked from OISF/suricata
-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Use consistent header style and wrap at 80 chars for better reading in a terminal.
- Loading branch information
Showing
1 changed file
with
78 additions
and
52 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,118 +1,144 @@ | ||
Suricata | ||
======== | ||
# Suricata | ||
|
||
[![Fuzzing Status](https://oss-fuzz-build-logs.storage.googleapis.com/badges/suricata.svg)](https://bugs.chromium.org/p/oss-fuzz/issues/list?sort=-opened&can=1&q=proj:suricata) | ||
[![codecov](https://codecov.io/gh/OISF/suricata/branch/master/graph/badge.svg?token=QRyyn2BSo1)](https://codecov.io/gh/OISF/suricata) | ||
|
||
Introduction | ||
------------ | ||
## Introduction | ||
|
||
[Suricata](https://suricata.io) is a network IDS, IPS and NSM engine developed by the [OISF](https://oisf.net) and the Suricata community. | ||
[Suricata](https://suricata.io) is a network IDS, IPS and NSM engine | ||
developed by the [OISF](https://oisf.net) and the Suricata community. | ||
|
||
Installation | ||
------------ | ||
## Installation | ||
|
||
https://docs.suricata.io/en/latest/install.html | ||
|
||
User Guide | ||
---------- | ||
## User Guide | ||
|
||
You can follow the [Suricata user guide](https://docs.suricata.io/en/latest/) to get started. | ||
You can follow the [Suricata user | ||
guide](https://docs.suricata.io/en/latest/) to get started. | ||
|
||
Contributing | ||
------------ | ||
## Contributing | ||
|
||
We're happily taking patches and other contributions. Please see our | ||
[Contribution Process](https://docs.suricata.io/en/latest/devguide/codebase/contributing/contribution-process.html) | ||
[Contribution | ||
Process](https://docs.suricata.io/en/latest/devguide/codebase/contributing/contribution-process.html) | ||
for how to get started. | ||
|
||
Suricata is a complex piece of software dealing with mostly untrusted input. Mishandling this input will have serious consequences: | ||
Suricata is a complex piece of software dealing with mostly untrusted | ||
input. Mishandling this input will have serious consequences: | ||
|
||
* in IPS mode a crash may knock a network offline; | ||
* in passive mode a compromise of the IDS may lead to loss of critical and confidential data; | ||
* in passive mode a compromise of the IDS may lead to loss of critical | ||
and confidential data; | ||
* missed detection may lead to undetected compromise of the network. | ||
|
||
In other words, we think the stakes are pretty high, especially since in many common cases the IDS/IPS will be directly reachable by an attacker. | ||
In other words, we think the stakes are pretty high, especially since | ||
in many common cases the IDS/IPS will be directly reachable by an | ||
attacker. | ||
|
||
For this reason, we have developed a QA process that is quite extensive. A consequence is that contributing to Suricata can be a somewhat lengthy process. | ||
For this reason, we have developed a QA process that is quite | ||
extensive. A consequence is that contributing to Suricata can be a | ||
somewhat lengthy process. | ||
|
||
On a high level, the steps are: | ||
|
||
1. GitHub-CI based checks. This runs automatically when a pull request is made. | ||
|
||
1. GitHub-CI based checks. This runs automatically when a pull request | ||
is made. | ||
2. Review by devs from the team and community | ||
|
||
3. QA runs from private QA setups. These are private due to the nature of the test traffic. | ||
|
||
3. QA runs from private QA setups. These are private due to the nature | ||
of the test traffic. | ||
|
||
### Overview of Suricata's QA steps | ||
|
||
OISF team members are able to submit builds to our private QA setup. It will run a series of build tests and a regression suite to confirm no existing features break. | ||
OISF team members are able to submit builds to our private QA | ||
setup. It will run a series of build tests and a regression suite to | ||
confirm no existing features break. | ||
|
||
The final QA runs takes a few hours minimally, and generally runs overnight. It currently runs: | ||
The final QA runs takes a few hours minimally, and generally runs | ||
overnight. It currently runs: | ||
|
||
- extensive build tests on different OS', compilers, optimization levels, configure features | ||
- extensive build tests on different OS', compilers, optimization | ||
levels, configure features | ||
- static code analysis using cppcheck, scan-build | ||
- runtime code analysis using valgrind, AddressSanitizer, LeakSanitizer | ||
- runtime code analysis using valgrind, AddressSanitizer, | ||
LeakSanitizer | ||
- regression tests for past bugs | ||
- output validation of logging | ||
- unix socket testing | ||
- pcap based fuzz testing using ASAN and LSAN | ||
- traffic replay based IDS and IPS tests | ||
|
||
Next to these tests, based on the type of code change further tests can be run manually: | ||
Next to these tests, based on the type of code change further tests | ||
can be run manually: | ||
|
||
- traffic replay testing (multi-gigabit) | ||
- large pcap collection processing (multi-terabytes) | ||
- fuzz testing (might take multiple days or even weeks) | ||
- pcap based performance testing | ||
- live performance testing | ||
- various other manual tests based on evaluation of the proposed changes | ||
|
||
|
||
It's important to realize that almost all of the tests above are used as acceptance tests. If something fails, it's up to you to address this in your code. | ||
|
||
|
||
One step of the QA is currently run post-merge. We submit builds to the Coverity Scan program. Due to limitations of this (free) service, we can submit once a day max. | ||
Of course it can happen that after the merge the community will find issues. For both cases we request you to help address the issues as they may come up. | ||
- various other manual tests based on evaluation of the proposed | ||
changes | ||
|
||
It's important to realize that almost all of the tests above are used | ||
as acceptance tests. If something fails, it's up to you to address | ||
this in your code. | ||
|
||
One step of the QA is currently run post-merge. We submit builds to | ||
the Coverity Scan program. Due to limitations of this (free) service, | ||
we can submit once a day max. Of course it can happen that after the | ||
merge the community will find issues. For both cases we request you to | ||
help address the issues as they may come up. | ||
|
||
|
||
### FAQ | ||
## FAQ | ||
|
||
__Q: Will you accept my PR?__ | ||
|
||
A: That depends on a number of things, including the code quality. With new features it also depends on whether the team and/or the community think the feature is useful, how much it affects other code and features, the risk of performance regressions, etc. | ||
|
||
A: That depends on a number of things, including the code | ||
quality. With new features it also depends on whether the team and/or | ||
the community think the feature is useful, how much it affects other | ||
code and features, the risk of performance regressions, etc. | ||
|
||
__Q: When will my PR be merged?__ | ||
|
||
A: It depends, if it's a major feature or considered a high risk change, it will probably go into the next major version. | ||
|
||
A: It depends, if it's a major feature or considered a high risk | ||
change, it will probably go into the next major version. | ||
|
||
__Q: Why was my PR closed?__ | ||
|
||
A: As documented in the [Suricata GitHub workflow](https://docs.suricata.io/en/latest/devguide/codebase/contributing/github-pr-workflow.html), | ||
A: As documented in the [Suricata GitHub | ||
workflow](https://docs.suricata.io/en/latest/devguide/codebase/contributing/github-pr-workflow.html), | ||
we expect a new pull request for every change. | ||
|
||
Normally, the team (or community) will give feedback on a pull request after which | ||
it is expected to be replaced by an improved PR. So look at the comments. If you | ||
disagree with the comments we can still discuss them in the closed PR. | ||
|
||
If the PR was closed without comments it's likely due to QA failure. If the GitHub-CI checks failed, the PR should be fixed right away. No need for a discussion about it, unless you believe the QA failure is incorrect. | ||
Normally, the team (or community) will give feedback on a pull request | ||
after which it is expected to be replaced by an improved PR. So look | ||
at the comments. If you disagree with the comments we can still | ||
discuss them in the closed PR. | ||
|
||
If the PR was closed without comments it's likely due to QA | ||
failure. If the GitHub-CI checks failed, the PR should be fixed right | ||
away. No need for a discussion about it, unless you believe the QA | ||
failure is incorrect. | ||
|
||
__Q: the compiler/code analyser/tool is wrong, what now?__ | ||
|
||
A: To assist in the automation of the QA, we're not accepting warnings or errors to stay. In some cases this could mean that we add a suppression if the tool supports that (e.g. valgrind, DrMemory). Some warnings can be disabled. In some exceptional cases the only 'solution' is to refactor the code to work around a static code checker limitation false positive. While frustrating, we prefer this over leaving warnings in the output. Warnings tend to get ignored and then increase risk of hiding other warnings. | ||
|
||
A: To assist in the automation of the QA, we're not accepting warnings | ||
or errors to stay. In some cases this could mean that we add a | ||
suppression if the tool supports that (e.g. valgrind, DrMemory). Some | ||
warnings can be disabled. In some exceptional cases the only | ||
'solution' is to refactor the code to work around a static code | ||
checker limitation false positive. While frustrating, we prefer this | ||
over leaving warnings in the output. Warnings tend to get ignored and | ||
then increase risk of hiding other warnings. | ||
|
||
__Q: I think your QA test is wrong__ | ||
|
||
A: If you really think it is, we can discuss how to improve it. But don't come to this conclusion too quickly, more often it's the code that turns out to be wrong. | ||
|
||
A: If you really think it is, we can discuss how to improve it. But | ||
don't come to this conclusion too quickly, more often it's the code | ||
that turns out to be wrong. | ||
|
||
__Q: do you require signing of a contributor license agreement?__ | ||
|
||
A: Yes, we do this to keep the ownership of Suricata in one hand: the Open Information Security Foundation. See http://suricata.io/about/open-source/ and http://suricata.io/about/contribution-agreement/ | ||
A: Yes, we do this to keep the ownership of Suricata in one hand: the | ||
Open Information Security Foundation. See | ||
http://suricata.io/about/open-source/ and | ||
http://suricata.io/about/contribution-agreement/ |