Skip to content

Commit

Permalink
Merge branch 'master' into hidanio/multiple_path_dnr
Browse files Browse the repository at this point in the history
  • Loading branch information
Hidanio authored Jul 23, 2024
2 parents f8ce256 + a754718 commit 7bcf05b
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 2 deletions.
4 changes: 2 additions & 2 deletions docs/_config.yml
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
theme: minimal
markdown: kramdown
remote_theme: pages-themes/minimal@v0.2.0
markdown: kramdown
2 changes: 2 additions & 0 deletions src/rules/parser.go
Original file line number Diff line number Diff line change
Expand Up @@ -142,6 +142,8 @@ func (p *parser) parseRuleInfo(st ir.Node, labelStmt ir.Node, proto *Rule) (Rule
rule.Message = proto.Message
rule.Location = proto.Location
rule.Paths = proto.Paths
rule.PathExcludes = proto.PathExcludes


Check failure on line 147 in src/rules/parser.go

View workflow job for this annotation

GitHub Actions / Build

File is not `gofmt`-ed with `-s` (gofmt)

Check failure on line 147 in src/rules/parser.go

View workflow job for this annotation

GitHub Actions / Build

File is not `gofmt`-ed with `-s` (gofmt)
rule.Filters = make([]map[string]Filter, len(proto.Filters))
for i, filterSet := range proto.Filters {
Expand Down
48 changes: 48 additions & 0 deletions src/tests/rules/rules_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -518,3 +518,51 @@ function type_type_check(string $animal_name, int $animal_id) {
}
test.RunRulesTest()
}

func TestRulePathExcludePositive(t *testing.T) {
rfile := `<?php
/**
* @name varEval
* @warning don't eval from variable
* @path www/
* @path-exclude www/no
*/
eval(${"var"});
`
test := linttest.NewSuite(t)
test.RuleFile = rfile
code := `<?php
$hello = 'echo 123;';
eval($hello);
eval('echo 456;');
`
test.AddNamedFile("www/no", code)

test.RunRulesTest()
}

func TestRulePathExcludeNegative(t *testing.T) {
rfile := `<?php
/**
* @name varEval
* @warning don't eval from variable
* @path www/
* @path-exclude www/no
*/
eval(${"var"});
`
test := linttest.NewSuite(t)
test.RuleFile = rfile
code := `<?php
$hello = 'echo 123;';
eval($hello);
eval('echo 456;');
`
test.AddNamedFile("www/no", code)
test.AddNamedFile("www/yes", code)

test.Expect = []string{
`don't eval from variable`,
}
test.RunRulesTest()
}

0 comments on commit 7bcf05b

Please sign in to comment.