|
1 | 1 | local Anagram = require('anagram')
|
2 | 2 |
|
3 | 3 | describe('anagram', function()
|
| 4 | + local function sorted_clone(t) |
| 5 | + local clone = {} |
| 6 | + for k, v in pairs(t) do |
| 7 | + clone[k] = v |
| 8 | + end |
| 9 | + table.sort(clone) |
| 10 | + return clone |
| 11 | + end |
| 12 | + |
| 13 | + local function assert_lists_are_same(expected, actual) |
| 14 | + assert.are.same(sorted_clone(expected), sorted_clone(actual)) |
| 15 | + end |
| 16 | + |
4 | 17 | it('no result', function()
|
5 | 18 | local detector = Anagram:new('diaper')
|
6 | 19 | local result = detector:match({ 'hello', 'world', 'zombies', 'pants' })
|
7 | 20 | local expected = {}
|
8 |
| - assert.are.same(expected, result) |
| 21 | + assert_lists_are_same(expected, result) |
9 | 22 | end)
|
10 | 23 |
|
11 | 24 | it('detects simple anagram', function()
|
12 | 25 | local detector = Anagram:new('ant')
|
13 | 26 | local result = detector:match({ 'tan', 'stand', 'at' })
|
14 | 27 | local expected = { 'tan' }
|
15 |
| - assert.are.same(expected, result) |
| 28 | + assert_lists_are_same(expected, result) |
16 | 29 | end)
|
17 | 30 |
|
18 | 31 | it('does not detect false positives', function()
|
19 | 32 | local detector = Anagram:new('galea')
|
20 | 33 | local result = detector:match({ 'eagle' })
|
21 | 34 | local expected = {}
|
22 |
| - assert.are.same(expected, result) |
| 35 | + assert_lists_are_same(expected, result) |
23 | 36 | end)
|
24 | 37 |
|
25 | 38 | it('detects multiple anagrams', function()
|
26 | 39 | local detector = Anagram:new('master')
|
27 | 40 | local result = detector:match({ 'stream', 'pigeon', 'maters' })
|
28 | 41 | local expected = { 'stream', 'maters' }
|
29 |
| - assert.are.same(expected, result) |
| 42 | + assert_lists_are_same(expected, result) |
30 | 43 | end)
|
31 | 44 |
|
32 | 45 | it('does not detect anagram subsets', function()
|
33 | 46 | local detector = Anagram:new('good')
|
34 | 47 | local result = detector:match({ 'dog', 'goody' })
|
35 | 48 | local expected = {}
|
36 |
| - assert.are.same(expected, result) |
| 49 | + assert_lists_are_same(expected, result) |
37 | 50 | end)
|
38 | 51 |
|
39 | 52 | it('detects anagram', function()
|
40 | 53 | local detector = Anagram:new('listen')
|
41 | 54 | local result = detector:match({ 'enlists', 'google', 'inlets', 'banana' })
|
42 | 55 | local expected = { 'inlets' }
|
43 |
| - assert.are.same(expected, result) |
| 56 | + assert_lists_are_same(expected, result) |
44 | 57 | end)
|
45 | 58 |
|
46 | 59 | it('detects multiple anagrams', function()
|
47 | 60 | local detector = Anagram:new('allergy')
|
48 | 61 | local result = detector:match({ 'gallery', 'ballerina', 'regally', 'clergy', 'largely', 'leading' })
|
49 | 62 | local expected = { 'gallery', 'regally', 'largely' }
|
50 |
| - assert.are.same(expected, result) |
| 63 | + assert_lists_are_same(expected, result) |
51 | 64 | end)
|
52 | 65 |
|
53 | 66 | it('detects anagrams case-insensitively', function()
|
54 | 67 | local detector = Anagram:new('Orchestra')
|
55 | 68 | local result = detector:match({ 'cashregister', 'Carthorse', 'radishes' })
|
56 | 69 | local expected = { 'Carthorse' }
|
57 |
| - assert.are.same(expected, result) |
| 70 | + assert_lists_are_same(expected, result) |
58 | 71 | end)
|
59 | 72 | end)
|
0 commit comments