|
| 1 | +package ruby |
| 2 | + |
| 3 | +import ( |
| 4 | + "strings" |
| 5 | + "testing" |
| 6 | +) |
| 7 | + |
| 8 | +func TestCheckVersionGuards(t *testing.T) { |
| 9 | + cases := map[string]struct { |
| 10 | + fileText string |
| 11 | + expectedResults []string |
| 12 | + }{ |
| 13 | + "allow standard format targeting ga": { |
| 14 | + fileText: "some text\n<% unless version == 'ga' -%>\nmore text", |
| 15 | + expectedResults: nil, |
| 16 | + }, |
| 17 | + "disallow targeting beta": { |
| 18 | + fileText: "some text\n<% unless version == 'beta' -%>\nmore text", |
| 19 | + expectedResults: []string{"2: <% unless version == 'beta' -%>"}, |
| 20 | + }, |
| 21 | + "disallow 'if not'": { |
| 22 | + fileText: "some text\n<% if version != 'ga' -%>\nmore text", |
| 23 | + expectedResults: []string{"2: <% if version != 'ga' -%>"}, |
| 24 | + }, |
| 25 | + "disallow single '='": { |
| 26 | + fileText: "some text\n<% unless version = 'ga' -%>\nmore text", |
| 27 | + expectedResults: []string{"2: <% unless version = 'ga' -%>"}, |
| 28 | + }, |
| 29 | + "disallow leaving trailing line break": { |
| 30 | + fileText: "some text\n<% unless version == 'ga' %>\nmore text", |
| 31 | + expectedResults: []string{"2: <% unless version == 'ga' %>"}, |
| 32 | + }, |
| 33 | + "one valid, one invalid": { |
| 34 | + fileText: "some text\n<% unless version == 'beta' -%>\nmore text\n<% unless version == 'ga' -%>", |
| 35 | + expectedResults: []string{"2: <% unless version == 'beta' -%>"}, |
| 36 | + }, |
| 37 | + "multiple invalid": { |
| 38 | + fileText: "some text\n<% unless version == 'beta' -%>\nmore text\n\n\n<% if version == \"beta\" -%>", |
| 39 | + expectedResults: []string{"2: <% unless version == 'beta' -%>", "6: <% if version == \"beta\" -%>"}, |
| 40 | + }, |
| 41 | + } |
| 42 | + |
| 43 | + for tn, tc := range cases { |
| 44 | + tc := tc |
| 45 | + t.Run(tn, func(t *testing.T) { |
| 46 | + t.Parallel() |
| 47 | + results := CheckVersionGuards(strings.NewReader(tc.fileText)) |
| 48 | + if len(results) != len(tc.expectedResults) { |
| 49 | + t.Errorf("Expected length %d, got %d", len(tc.expectedResults), len(results)) |
| 50 | + return |
| 51 | + } |
| 52 | + for i, result := range results { |
| 53 | + if result != tc.expectedResults[i] { |
| 54 | + t.Errorf("Expected %v, got %v", tc.expectedResults[i], result) |
| 55 | + } |
| 56 | + } |
| 57 | + }) |
| 58 | + } |
| 59 | +} |
0 commit comments