source: .tests/test1.py @ c248e37

Last change on this file since c248e37 was c248e37, checked in by / <>, at 2021-03-16T14:33:01Z

formatting

  • Property mode set to 100644
File size: 5.3 KB
Line 
1import socket
2import sys
3import time
4import select
5
6YESTEST = True
7MESSAGETEST = True
8BLOCKTEST = False
9OFFLINETEST = False
10RENAMETEST = True
11SHOWLOG = True
12
13FAILED = []
14
15SEPARATOR = "="*60
16SMOLPARATOR = "-"*60
17
18class IrcClient:
19    def __init__(self, nick, pwd):
20        self.nick = nick
21        self.pwd = pwd
22        self.log = ''
23        self.tmplog = ''
24        self.sck = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
25
26    def send_raw(self, msg, loud = False):
27        self.receive()
28        if loud:
29            print('FROM '+ self.nick + '|| ' + msg)
30        self.log += msg+'\r\n'
31        self.tmplog += msg+'\r\n'
32        self.sck.send((msg+'\r\n').encode())
33
34    def send_priv_msg(self, recip, msg, loud = True):
35        self.send_raw('PRIVMSG '+recip+' :'+msg, loud)
36
37    def connect(self):
38        try:
39            self.sck.connect(('127.0.0.1', 6667))
40        except:
41            print("IRC connection failed for " + self.nick)
42            sys.exit(1)
43       
44        print("IRC connection established for " + self.nick)
45
46        self.send_raw('USER ' + (self.nick + " ")*3)
47        self.send_raw('NICK ' + self.nick)
48        self.send_raw('JOIN &bitlbee')
49
50    def jabber_login(self):
51        self.send_priv_msg("&bitlbee", "account add jabber "+self.nick+"@localhost "+self.pwd)
52        time.sleep(0.3)
53        self.send_priv_msg("&bitlbee", "account on")
54        time.sleep(1)
55        self.receive()
56        if self.log.find('Logged in') == -1:
57            print("Jabber login failed for " + self.nick)
58            sys.exit(1)
59        else:
60            print("Jabber login successful for " + self.nick)
61
62    def receive(self):
63        text = ''
64        while True:
65            readable, _, _ = select.select([self.sck], [], [], 5)
66            if self.sck in readable:
67                text += self.sck.recv(2040).decode()
68                for line in text.split('\n'):
69                    if line.find('PING') != -1:
70                        self.send_raw('PONG ' + line.split()[1])
71            else:
72                break
73        self.log += text
74        self.tmplog += text
75        return text
76
77    def add_jabber_buddy(self, nick):
78        self.send_priv_msg("&bitlbee", "add 0 " + nick+"@localhost")
79   
80    def block_jabber_buddy(self, nick):
81        self.send_priv_msg("&bitlbee", "block " + nick)
82
83    def unblock_jabber_buddy(self, nick):
84        self.send_priv_msg("&bitlbee", "allow " + nick)
85
86    def rename_jabber_buddy(self, oldnick, newnick):
87        self.send_priv_msg("&bitlbee", "rename " + oldnick + " " + newnick)
88       
89def msg_comes_thru(sender, receiver, message):
90    sender.send_priv_msg(receiver.nick, message)
91    received = receiver.receive().find(message) != -1
92    return received
93
94def perform_test(clis, test_function, test_name):
95    global FAILED
96    for cli in clis:
97        cli.tmplog=""
98
99    print("\n"+SEPARATOR)
100    print("Test: "+test_name)
101
102    if test_function(clis):
103        print("Test passed")
104    else:
105        print("Test failed")
106        FAILED += [test_name]
107
108        for cli in clis:
109            if cli.tmplog != "":
110                print(SMOLPARATOR)
111                print("Test Log "+ cli.nick+":")
112                print(cli.tmplog)
113
114    print(SEPARATOR)
115
116def yes_test(clis):
117    ret = False
118    for _ in range(100):
119        clis[0].send_raw("yes", loud = False)
120        clis[0].receive()
121        if (not ret) and clis[0].log.find("Did I ask you something?"):
122            ret = True
123        if clis[0].log.find("Buuuuuuuuuuuuuuuurp"):
124            print("The RNG gods smile upon us")
125            break
126    return ret
127
128def message_test(clis):
129    print("Test: Send message")
130    ret = msg_comes_thru(clis[0], clis[1], 'ohai <3')
131    ret = ret & msg_comes_thru(clis[1], clis[0], 'uwu *pounces*')
132    return ret
133
134def block_test(clis):
135    clis[0].block_jabber_buddy(clis[1].nick)
136    ret = not msg_comes_thru(clis[1], clis[0], 'm-meow?')
137    clis[0].unblock_jabber_buddy(clis[1].nick)
138    ret = ret & msg_comes_thru(clis[1], clis[0], '*purrs*')
139    return ret
140
141def rename_test(clis):
142    newname = "xXx_pup_LINKENPARK4EVA"
143    message = "rawr meanmz i luv<3 u in dinosaur"
144
145    clis[0].rename_jabber_buddy(clis[1].nick, newname)
146    clis[0].send_priv_msg(newname, message)
147    ret = clis[1].receive().find(message) != -1
148
149    clis[0].rename_jabber_buddy("-del", newname)
150    ret = ret & msg_comes_thru(clis[0], clis[1], "rawr")
151    return ret
152
153def run_tests():
154    global FAILED
155    clis = []
156    clis += [IrcClient('test1', 'asd')]
157    clis += [IrcClient('test2', 'asd')]
158    for cli in clis:
159        cli.connect()
160
161    if YESTEST:
162        perform_test(clis, yes_test, "Yes")
163
164    for cli in clis:
165        cli.jabber_login()
166    clis[0].add_jabber_buddy(clis[1].nick)
167
168    if MESSAGETEST:
169        perform_test(clis, message_test, "Send message")
170
171    if BLOCKTEST:
172        perform_test(clis, block_test, "Block user")
173
174    if RENAMETEST:
175        perform_test(clis, rename_test, "Rename user")
176
177    if FAILED or SHOWLOG:
178        print("")
179        for cli in clis:
180            print(SMOLPARATOR)
181            print("Log "+ cli.nick+":")
182            print(cli.log)
183        print(SMOLPARATOR)
184
185    if FAILED:
186        print("\n" + SEPARATOR + "\nSome test have failed:")
187        for fail in FAILED:
188            print(fail)
189    else:
190        print("\n" + SEPARATOR + "\nAll tests have passed")
191   
192if __name__ == "__main__":
193    global FAILED
194    run_tests()
195    if FAILED:
196        sys.exit(1)
Note: See TracBrowser for help on using the repository browser.