/
SumGrammarTest.cs
109 lines (98 loc) · 3.3 KB
/
SumGrammarTest.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
using Axaprj.LexFeatExtr.Grammar;
using Axaprj.LexFeatExtr.Grammar.Attributes;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using Xunit;
using Xunit.Abstractions;
namespace Axaprj.LexFeatExtr.Tests
{
public class SumGrammarTest : TestBase
{
public SumGrammarTest(ITestOutputHelper output) : base(output) { }
protected override Productions Prod
=> new ProdsSum();
protected override Productions.Grammar Grammar
=> new ProdsSum.SumGrammar();
public enum SYM
{
[NonTerm]
Text,
[AnyToken(addToResult: false)]
ignore,
[Empty]
eof,
[CollectCount]
finished
}
public enum TcSYM
{
[TextC(":Word(sums)")]
sum,
[TextC(":Word(and) num:Integer)", "num:Integer")]
num,
[NonTerm]
Args
}
public partial class ProdsSum : Productions
{
internal class SumGrammar : Grammar
{
public SumGrammar() : base(SYM.Text)
{
AddRULE(SYM.Text,
EXPR(TcSYM.sum, TcSYM.Args, SYM.Text),
EXPR(TcSYM.Args, TcSYM.sum, SYM.Text),
EXPR(SYM.ignore, SYM.Text),
EXPR(SYM.eof)
);
AddRULE(TcSYM.Args,
EXPR(TcSYM.num, TcSYM.Args),
EXPR(SYM.finished)
);
}
}
}
[Fact]
public void DevSumTest1()
{
var prod = Produce("sums 5 6 ");
Assert.NotNull(prod);
Log($"Prod: '{prod}'");
Assert.True(prod.TryFind(TcSYM.sum, out List<IProd> prod_sum));
Assert.Single(prod_sum);
Assert.True(prod.TryFind(TcSYM.Args, out List<IProd> prod_args));
Assert.Single(prod_args);
var args = ((INonTermProd)prod_args[0]);
Assert.Equal(2, args.ComponentsCount);
}
[Fact]
public void DevSumTest2()
{
var prod = Produce("sums 5 6 and 7");
Assert.NotNull(prod);
Log($"Prod: '{prod}'");
Assert.True(prod.TryFind(TcSYM.sum, out List<IProd> prod_sum));
Assert.Single(prod_sum);
Assert.True(prod.TryFind(TcSYM.Args, out List<IProd> prod_args));
Assert.Single(prod_args);
var args = ((INonTermProd)prod_args[0]).Components;
Assert.NotNull(args);
Assert.Equal(18, args.Sum(iterm => ((ITermValue<int>)iterm).Value));
}
[Fact]
public void DevSumTest3()
{
var prod = Produce("5 6 and 7 sums");
Assert.NotNull(prod);
Log($"Prod: '{prod}'");
Assert.True(prod.TryFind(TcSYM.sum, out List<IProd> prod_sum));
Assert.Single(prod_sum);
Assert.True(prod.TryFind(TcSYM.Args, out List<IProd> prod_args));
Assert.Single(prod_args);
var args = ((INonTermProd)prod_args[0]).Components;
Assert.NotNull(args);
Assert.Equal(18, args.Sum(iterm => ((ITermValue<int>)iterm).Value));
}
}
}