suricata
detect-template.c
Go to the documentation of this file.
1 /* Copyright (C) 2015-2018 Open Information Security Foundation
2  *
3  * You can copy, redistribute or modify this Program under the terms of
4  * the GNU General Public License version 2 as published by the Free
5  * Software Foundation.
6  *
7  * This program is distributed in the hope that it will be useful,
8  * but WITHOUT ANY WARRANTY; without even the implied warranty of
9  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10  * GNU General Public License for more details.
11  *
12  * You should have received a copy of the GNU General Public License
13  * version 2 along with this program; if not, write to the Free Software
14  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
15  * 02110-1301, USA.
16  */
17 
18 #include "../suricata-common.h"
19 #include "../util-unittest.h"
20 
21 #include "../detect-parse.h"
22 #include "../detect-engine.h"
23 
24 #include "../detect-template.h"
25 
26 /**
27  * \test test keyword parsing
28  */
29 
30 static int DetectTemplateParseTest01 (void)
31 {
32  DetectTemplateData *templated = DetectTemplateParse("1,10");
33  FAIL_IF_NULL(templated);
34  FAIL_IF(!(templated->arg1 == 1 && templated->arg2 == 10));
35  DetectTemplateFree(templated);
36  PASS;
37 }
38 
39 /**
40  * \test test signature parsing
41  */
42 
43 static int DetectTemplateSignatureTest01 (void)
44 {
46  FAIL_IF_NULL(de_ctx);
47 
48  Signature *sig = DetectEngineAppendSig(de_ctx, "alert ip any any -> any any (template:1,10; sid:1; rev:1;)");
49  FAIL_IF_NULL(sig);
50 
51  DetectEngineCtxFree(de_ctx);
52  PASS;
53 }
54 
55 /**
56  * \brief this function registers unit tests for DetectTemplate
57  */
59 {
60  UtRegisterTest("DetectTemplateParseTest01", DetectTemplateParseTest01);
61  UtRegisterTest("DetectTemplateSignatureTest01",
62  DetectTemplateSignatureTest01);
63 }
Signature * DetectEngineAppendSig(DetectEngineCtx *de_ctx, const char *sigstr)
Parse and append a Signature into the Detection Engine Context signature list.
#define PASS
Pass the test.
#define FAIL_IF(expr)
Fail a test if expression evaluates to false.
Definition: util-unittest.h:71
Signature container.
Definition: detect.h:495
main detection engine ctx
Definition: detect.h:723
void UtRegisterTest(const char *name, int(*TestFn)(void))
Register unit test.
#define FAIL_IF_NULL(expr)
Fail a test if expression evaluates to NULL.
Definition: util-unittest.h:89
void DetectTemplateRegisterTests(void)
this function registers unit tests for DetectTemplate
void DetectEngineCtxFree(DetectEngineCtx *)
Free a DetectEngineCtx::
DetectEngineCtx * DetectEngineCtxInit(void)