File: faop_determinize.test

package info (click to toggle)
tcllib 1.20%2Bdfsg-1
  • links: PTS
  • area: main
  • in suites: bullseye
  • size: 68,064 kB
  • sloc: tcl: 216,842; ansic: 14,250; sh: 2,846; xml: 1,766; yacc: 1,145; pascal: 881; makefile: 107; perl: 84; f90: 84; python: 33; ruby: 13; php: 11
file content (117 lines) | stat: -rw-r--r-- 3,479 bytes parent folder | download | duplicates (10)
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
110
111
112
113
114
115
116
117
# -*- tcl -*-
# fa_operations.test:  tests for the FA operations.
#
# Copyright (c) 2004-2007 by Andreas Kupries <andreas_kupries@users.sourceforge.net>
#
# RCS: @(#) $Id: faop_determinize.test,v 1.4 2007/04/12 03:43:15 andreas_kupries Exp $

# -------------------------------------------------------------------------

test faop-determinize-${setimpl}-1.0 {determinize, error} {
    catch {grammar::fa::op::determinize} res
    set res
} {wrong # args: should be "grammar::fa::op::determinize fa ?mapvar? ?idstart?"}


test faop-determinize-${setimpl}-1.1 {determinize, error} {
    catch {grammar::fa::op::determinize a b c d} res
    set res
} {wrong # args: should be "grammar::fa::op::determinize fa ?mapvar? ?idstart?"}


test faop-determinize-${setimpl}-1.2 {determinize, error} {
    catch {grammar::fa::op::determinize a} res
    set res
} {invalid command name "a"}


# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~


foreach {n code st fin mapres result} {
    00 datom x y {}
    {grammar::fa @ {x {1 0 {@ y}} y {0 1 {}}}}

    01 dalt  u z {0 {u v w} 1 {y z} 2 {x z}}
    {grammar::fa {@ =} {0 {1 0 {@ 2 = 1}} 1 {0 1 {}} 2 {0 1 {}}}}

    02 dopt  u x {0 {u v x} 1 {w x}}
    {grammar::fa @ {0 {1 1 {@ 1}} 1 {0 1 {}}}}

    03 drep  u x {0 {u v x} 1 {u v w x}} 
    {grammar::fa @ {0 {1 1 {@ 1}} 1 {0 1 {@ 1}}}}
} {
    set key ${n}.${code}

    test faop-determinize-${setimpl}-2.$key {determinize, bounded} {
	grammar::fa a
	gen $code
	a start add $st
	a final add $fin
	grammar::fa::op::determinize a map
	set res [validate_serial $result a]
	lappend res [string equal $mapres [dictsort $map]]
	lappend res [a is deterministic]
	a destroy
	set res
    } {ok 1 1}

    test faop-determinize-${setimpl}-3.$key {determinize, bounded, as method} {
	grammar::fa a
	gen $code
	a start add $st
	a final add $fin
	a determinize map
	set res [validate_serial $result a]
	lappend res [string equal $mapres [dictsort $map]]
	lappend res [a is deterministic]
	a destroy
	set res
    } {ok 1 1}
}


# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~


foreach {n code mapres result} {
    00 datom {0 x 1 y}
    {grammar::fa @ {0 {0 0 {@ 1}} 1 {0 0 {}}}}

    01 dalt  {0 x 1 y 2 u 3 z 4 v 5 w 6 {y z} 7 {x z}}
    {grammar::fa {@ =} {0 {0 0 {}} 1 {0 0 {}} 2 {0 0 {@ 7 = 6}} 3 {0 0 {}} 4 {0 0 {@ 7}} 5 {0 0 {= 6}} 6 {0 0 {}} 7 {0 0 {}}}}

    02 dopt  {0 x 1 u 2 v 3 w 4 {w x}}
    {grammar::fa @ {0 {0 0 {}} 1 {0 0 {@ 4}} 2 {0 0 {@ 4}} 3 {0 0 {}} 4 {0 0 {}}}}

    03 drep  {0 x 1 u 2 v 3 w 4 {u v w x}} 
    {grammar::fa @ {0 {0 0 {@ 4}} 1 {0 0 {@ 4}} 2 {0 0 {@ 4}} 3 {0 0 {@ 4}} 4 {0 0 {@ 4}}}}
} {
    set key ${n}.${code}

    test faop-determinize-${setimpl}-4.$key {determinize, unbounded} {
	grammar::fa a
	gen $code
	grammar::fa::op::determinize a map
	set res [validate_serial $result a]
	lappend res [string equal $mapres [dictsort $map]]
        lappend res [a is deterministic] ; # Never formally det, because of missing start.
	a destroy
	set res
    } {ok 1 0}

    test faop-determinize-${setimpl}-5.$key {determinize, unbounded, as method} {
	grammar::fa a
	gen $code
	a determinize map
	set res [validate_serial $result a]
	lappend res [string equal $mapres [dictsort $map]]
        lappend res [a is deterministic] ; # Never formally det, because of missing start.
	a destroy
	set res
    } {ok 1 0}
}


# -------------------------------------------------------------------------
::tcltest::cleanupTests