181ea0a34e37a0a45eb2c1a9ac0b80ac81a1295b
[mudpy.git] / bin / test
1 #!/usr/bin/env python
2 """Regression test script for the mudpy engine."""
3
4 # Copyright (c) 2004-2015 Jeremy Stanley <fungi@yuggoth.org>. Permission
5 # to use, copy, modify, and distribute this software is granted under
6 # terms provided in the LICENSE file distributed with this software.
7
8 import sys
9 import telnetlib
10
11 dialogue = (
12     # Create account 0
13     (0, "Identify yourself:", "luser0"),
14     (0, "Enter your choice:", "n"),
15     (0, "Enter a new password for \"luser0\":", "Test123"),
16     (0, "Enter the same new password again:", "Test123"),
17     (0, "What would you like to do\?", "c"),
18     (0, "Pick a birth gender for your new avatar:", "f"),
19     (0, "Choose a name for her:", "1"),
20     (0, "What would you like to do?", "a"),
21     (0, "Whom would you like to awaken?", ""),
22
23     # Create account 1
24     (1, "Identify yourself:", "luser1"),
25     (1, "Enter your choice:", "n"),
26     (1, "Enter a new password for \"luser1\":", "Test456"),
27     (1, "Enter the same new password again:", "Test456"),
28     (1, "What would you like to do\?", "c"),
29     (1, "Pick a birth gender for your new avatar:", "m"),
30     (1, "Choose a name for him:", "1"),
31     (1, "What would you like to do?", "a"),
32     (1, "Whom would you like to awaken?", ""),
33
34     # Actor appears from nowhere
35     (0, "You suddenly realize that .* is here\.", ""),
36
37     # Explicit punctuation
38     (0, "> ", "say Hello there!"),
39     (0, 'You exclaim, "Hello there\!"', ""),
40     (1, 'exclaims, "Hello there\!"', "say And you are?"),
41     (1, 'You ask, "And you are\?"', ""),
42     (0, 'asks, "And you are\?"', "say I'm me, of course."),
43     (0, 'You say, "I\'m me, of course\."', ""),
44     (1, 'says, "I\'m me, of course\."', "say I wouldn't be so sure..."),
45     (1, 'You muse, "I wouldn\'t be so sure\.\.\."', ""),
46     (0, 'muses, "I wouldn\'t be so sure\.\.\."', "say You mean,"),
47     (0, 'You begin, "You mean,"', ""),
48     (1, 'begins, "You mean,"', "say I know-"),
49     (1, 'You begin, "I know-"', ""),
50     (0, 'begins, "I know-"', "say Don't interrupt:"),
51     (0, 'You begin, "Don\'t interrupt:"', ""),
52     (1, 'begins, "Don\'t interrupt:"', "say I wasn't interrupting;"),
53     (1, 'You begin, "I wasn\'t interrupting;"', ""),
54     (0, 'begins, "I wasn\'t interrupting;"', ""),
55
56     # Implicit punctuation
57     (0, '> ', "say Whatever"),
58     (0, 'You say, "Whatever."', ""),
59     (1, 'says, "Whatever."', ""),
60
61     # Actor disappears
62     (1, "> ", "quit"),
63     (0, "You suddenly wonder where .* went\.", ""),
64
65     # Quit
66     (0, "> ", "quit"),
67
68     # Delete account 0
69     (0, "What would you like to do?", "d"),
70     (0, "Whom would you like to delete?", ""),
71     (0, "What would you like to do?", "p"),
72     (0, "permanently delete your account?", "y"),
73     (0, "Disconnecting...", ""),
74
75     # Delete account 1
76     (1, "What would you like to do?", "d"),
77     (1, "Whom would you like to delete?", ""),
78     (1, "What would you like to do?", "p"),
79     (1, "permanently delete your account?", "y"),
80     (1, "Disconnecting...", ""),
81 )
82
83 captures = ["", ""]
84 lusers = [telnetlib.Telnet(), telnetlib.Telnet()]
85 success = True
86 for luser in lusers:
87     luser.open("::1", 6669)
88 for conversant, question, answer in dialogue:
89     print("luser%s waiting for: %s" % (conversant, question))
90     index, match, received = lusers[conversant].expect(
91         [question.encode("utf-8")], 5)
92     captures[conversant] += received.decode("utf-8")
93     try:
94         captures[conversant] += lusers[
95             conversant].read_very_eager().decode("utf-8")
96     except:
97         pass
98     if index is not 0:
99         print("ERROR: luser%s did not receive expected string:\n\n%s"
100               % (conversant, question))
101         success = False
102         break
103     print("luser%s sending: %s" % (conversant, answer))
104     lusers[conversant].write(("%s\r\n" % answer).encode("utf-8"))
105     captures[conversant] += "%s\r\n" % answer
106 for conversant in range(len(captures)):
107     try:
108         captures[conversant] += lusers[
109             conversant].read_very_eager().decode("utf-8")
110     except:
111         pass
112     lusers[conversant].close()
113     log = open("capture_%s.log" % conversant, "w")
114     log.write(captures[conversant])
115     log.close()
116 if not success:
117     sys.exit(1)