1 // Copyright 2017-2019 VMware, Inc.
2 // SPDX-License-Identifier: BSD-2-Clause
3 //
4 // The BSD-2 license (the License) set forth below applies to all parts of the
5 // Cascade project.  You may not use this file except in compliance with the
6 // License.
7 //
8 // BSD-2 License
9 //
10 // Redistribution and use in source and binary forms, with or without
11 // modification, are permitted provided that the following conditions are met:
12 //
13 // 1. Redistributions of source code must retain the above copyright notice, this
14 // list of conditions and the following disclaimer.
15 //
16 // 2. Redistributions in binary form must reproduce the above copyright notice,
17 // this list of conditions and the following disclaimer in the documentation
18 // and/or other materials provided with the distribution.
19 //
20 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS AS IS AND
21 // ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
22 // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
23 // DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
24 // FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25 // DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
26 // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
27 // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
28 // OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 
31 #include "gtest/gtest.h"
32 #include "test/harness.h"
33 
34 using namespace cascade;
35 
TEST(parse,pass_and)36 TEST(parse, pass_and) {
37   run_parse("share/cascade/test/regression/parse/pass/and.v", false);
38 }
TEST(parse,pass_aoo)39 TEST(parse, pass_aoo) {
40   run_parse("share/cascade/test/regression/parse/pass/aoo.v", false);
41 }
TEST(parse,pass_assign_1)42 TEST(parse, pass_assign_1) {
43   run_parse("share/cascade/test/regression/parse/pass/assign_1.v", false);
44 }
TEST(parse,pass_assign_statement)45 TEST(parse, pass_assign_statement) {
46   run_parse("share/cascade/test/regression/parse/pass/assign_statement.v", false);
47 }
TEST(parse,pass_attributes)48 TEST(parse, pass_attributes) {
49   run_parse("share/cascade/test/regression/parse/pass/attributes.v", false);
50 }
TEST(parse,pass_case_statement)51 TEST(parse, pass_case_statement) {
52   run_parse("share/cascade/test/regression/parse/pass/case_statement.v", false);
53 }
TEST(parse,pass_conditional_statement)54 TEST(parse, pass_conditional_statement) {
55   run_parse("share/cascade/test/regression/parse/pass/conditional_statement.v", false);
56 }
TEST(parse,pass_construct)57 TEST(parse, pass_construct) {
58   run_parse("share/cascade/test/regression/parse/pass/construct.v", false);
59 }
TEST(parse,pass_continuous_assign)60 TEST(parse, pass_continuous_assign) {
61   run_parse("share/cascade/test/regression/parse/pass/continuous_assign.v", false);
62 }
TEST(parse,pass_declaration)63 TEST(parse, pass_declaration) {
64   run_parse("share/cascade/test/regression/parse/pass/declaration.v", false);
65 }
TEST(parse,pass_issue_6)66 TEST(parse, pass_issue_6) {
67   run_parse("share/cascade/test/regression/parse/pass/issue_6.v", false);
68 }
TEST(parse,pass_issue_224)69 TEST(parse, pass_issue_224) {
70   run_parse("share/cascade/test/regression/parse/pass/issue_224.v", false);
71 }
TEST(parse,pass_loop_statement)72 TEST(parse, pass_loop_statement) {
73   run_parse("share/cascade/test/regression/parse/pass/loop_statement.v", false);
74 }
TEST(parse,pass_module_declaration_1)75 TEST(parse, pass_module_declaration_1) {
76   run_parse("share/cascade/test/regression/parse/pass/module_declaration_1.v", false);
77 }
TEST(parse,pass_module_declaration_2)78 TEST(parse, pass_module_declaration_2) {
79   run_parse("share/cascade/test/regression/parse/pass/module_declaration_2.v", false);
80 }
TEST(parse,pass_module_declaration_3)81 TEST(parse, pass_module_declaration_3) {
82   run_parse("share/cascade/test/regression/parse/pass/module_declaration_3.v", false);
83 }
TEST(parse,pass_module_declaration_4)84 TEST(parse, pass_module_declaration_4) {
85   run_parse("share/cascade/test/regression/parse/pass/module_declaration_4.v", false);
86 }
TEST(parse,pass_module_declaration_5)87 TEST(parse, pass_module_declaration_5) {
88   run_parse("share/cascade/test/regression/parse/pass/module_declaration_5.v", false);
89 }
TEST(parse,pass_module_declaration_6)90 TEST(parse, pass_module_declaration_6) {
91   run_parse("share/cascade/test/regression/parse/pass/module_declaration_6.v", false);
92 }
TEST(parse,pass_module_declaration_7)93 TEST(parse, pass_module_declaration_7) {
94   run_parse("share/cascade/test/regression/parse/pass/module_declaration_7.v", false);
95 }
TEST(parse,pass_module_declaration_8)96 TEST(parse, pass_module_declaration_8) {
97   run_parse("share/cascade/test/regression/parse/pass/module_declaration_8.v", false);
98 }
TEST(parse,pass_port_declaration)99 TEST(parse, pass_port_declaration) {
100   run_parse("share/cascade/test/regression/parse/pass/port_declaration.v", false);
101 }
TEST(parse,pass_port_list)102 TEST(parse, pass_port_list) {
103   run_parse("share/cascade/test/regression/parse/pass/port_list.v", false);
104 }
TEST(parse,pass_system_task)105 TEST(parse, pass_system_task) {
106   run_parse("share/cascade/test/regression/parse/pass/system_task.v", false);
107 }
108 
TEST(parse,fail_assign_1)109 TEST(parse, fail_assign_1) {
110   run_parse("share/cascade/test/regression/parse/fail/assign_1.v", true);
111 }
TEST(parse,fail_missing_endmodule)112 TEST(parse, fail_missing_endmodule) {
113   run_parse("share/cascade/test/regression/parse/fail/missing_endmodule.v", true);
114 }
TEST(parse,fail_module_declaration_1)115 TEST(parse, fail_module_declaration_1) {
116   run_parse("share/cascade/test/regression/parse/fail/module_declaration_1.v", true);
117 }
TEST(parse,fail_module_declaration_2)118 TEST(parse, fail_module_declaration_2) {
119   run_parse("share/cascade/test/regression/parse/fail/module_declaration_2.v", true);
120 }
121