mirror of https://github.com/01-edu/public.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
57 lines
1.2 KiB
57 lines
1.2 KiB
package main |
|
|
|
import ( |
|
"strings" |
|
|
|
student "student" |
|
|
|
"github.com/01-edu/public/go/tests/lib" |
|
) |
|
|
|
func index(s string, substr string) int { |
|
return strings.Index(s, substr) |
|
} |
|
|
|
func main() { |
|
type node struct { |
|
s string |
|
toFind string |
|
} |
|
|
|
table := []node{} |
|
|
|
// the first 15 values are valid for this test |
|
for i := 0; i < 15; i++ { |
|
wordToTest := lib.RandASCII() |
|
firstLetterIndex := lib.RandIntBetween(0, (len(wordToTest)-1)/2) |
|
lastLetterIndex := lib.RandIntBetween(firstLetterIndex, len(wordToTest)-1) |
|
|
|
val := node{ |
|
s: wordToTest, |
|
toFind: wordToTest[firstLetterIndex:lastLetterIndex], |
|
} |
|
table = append(table, val) |
|
} |
|
|
|
// the next 15 values are supposed to be invalid for this test |
|
for i := 0; i < 15; i++ { |
|
wordToTest := lib.RandASCII() |
|
wrongMatch := lib.RandASCII() |
|
|
|
val := node{ |
|
s: wordToTest, |
|
toFind: wrongMatch, |
|
} |
|
table = append(table, val) |
|
} |
|
// those are the test values from the README examples |
|
table = append(table, |
|
node{s: "Hello!", toFind: "l"}, |
|
node{s: "Salut!", toFind: "alu"}, |
|
node{s: "Ola!", toFind: "hOl"}, |
|
) |
|
|
|
for _, arg := range table { |
|
lib.Challenge("Index", student.Index, index, arg.s, arg.toFind) |
|
} |
|
}
|
|
|