- Timestamp:
- 2021-03-29T13:14:39Z (4 years ago)
- Children:
- ef70f9f
- Parents:
- f7cd819
- Location:
- .tests
- Files:
-
- 3 added
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
.tests/cleanup_bitlbee.sh
rf7cd819 re14bdc67 5 5 killall bitlbee 6 6 7 printf ' \n\nBitlbee output:\n\n'7 printf 'Bitlbee output:\n\n' 8 8 less ./debuglog 9 9 -
.tests/jabber_send_msg.py
rf7cd819 re14bdc67 1 import socket 2 import sys 3 import time 4 import select 1 import btlib 5 2 6 SEPARATOR = "="*60 7 SMOLPARATOR = "-"*60 8 9 class IrcClient: 10 def __init__(self, nick, pwd): 11 self.nick = nick 12 self.pwd = pwd 13 self.log = '' 14 self.tmplog = '' 15 self.sck = socket.socket(socket.AF_INET, socket.SOCK_STREAM) 16 17 def send_raw(self, msg, loud = False, log = True): 18 self.receive() 19 if loud: 20 print('FROM '+ self.nick + '|| ' + msg) 21 if log: 22 self.log += msg+'\r\n' 23 self.tmplog += msg+'\r\n' 24 self.sck.send((msg+'\r\n').encode()) 25 26 def send_priv_msg(self, recip, msg, loud = False): 27 self.send_raw('PRIVMSG '+recip+' :'+msg, loud) 28 29 def connect(self): 30 connected = False 31 for x in range(5): 32 try: 33 self.sck.connect(('127.0.0.1', 6667)) 34 connected = True 35 break 36 except: 37 time.sleep(1) 38 39 if not connected: 40 print("IRC connection failed for " + self.nick) 41 sys.exit(1) 42 43 print("IRC connection established for " + self.nick) 44 45 self.send_raw('USER ' + (self.nick + " ")*3) 46 self.send_raw('NICK ' + self.nick) 47 self.send_raw('JOIN &bitlbee') 48 49 def jabber_login(self): 50 self.send_priv_msg("&bitlbee", "account add jabber "+self.nick+"@localhost "+self.pwd) 51 time.sleep(0.3) 52 self.send_priv_msg("&bitlbee", "account on") 53 time.sleep(1) 54 self.receive() 55 if self.log.find('Logged in') == -1: 56 print("Jabber login failed for " + self.nick) 57 sys.exit(1) 58 else: 59 print("Jabber login successful for " + self.nick) 60 61 def receive(self): 62 text = '' 63 while True: 64 readable, _, _ = select.select([self.sck], [], [], 5) 65 if self.sck in readable: 66 text += self.sck.recv(2040).decode() 67 for line in text.split('\n'): 68 if line.find('PING') != -1: 69 self.send_raw('PONG ' + line.split()[1]) 70 else: 71 break 72 self.log += text 73 self.tmplog += text 74 return text 75 76 def add_jabber_buddy(self, nick): 77 self.send_priv_msg("&bitlbee", "add 0 " + nick+"@localhost") 78 79 def block_jabber_buddy(self, nick): 80 self.send_priv_msg("&bitlbee", "block " + nick) 81 82 def unblock_jabber_buddy(self, nick): 83 self.send_priv_msg("&bitlbee", "allow " + nick) 84 85 def rename_jabber_buddy(self, oldnick, newnick): 86 self.send_priv_msg("&bitlbee", "rename " + oldnick + " " + newnick) 87 88 def msg_comes_thru(sender, receiver, message): 89 sender.send_priv_msg(receiver.nick, message) 90 received = receiver.receive().find(message) != -1 91 return received 92 93 94 def perform_test(test_function): 95 clis = [] 96 clis += [IrcClient('test1', 'asd')] 97 clis += [IrcClient('test2', 'asd')] 98 for cli in clis: 99 cli.connect() 100 101 fail = not test_function(clis) 102 103 for cli in clis: 104 cli.receive() 105 print(SEPARATOR) 106 print("Test Log "+ cli.nick+":") 107 print(cli.tmplog) 108 print(SEPARATOR) 109 110 111 if fail: 112 sys.exit(1) 113 114 115 def yes_test(clis): 116 ret = False 117 clis[0].send_priv_msg("&bitlbee", "yes") 118 clis[0].receive() 119 for x, fun in enumerate(FUN): 120 if (clis[0].log.find(fun) != -1): 121 ret = True 122 if x: 123 print("The RNG gods smile upon us") 124 break 3 def send_msg(clis): 4 ret = True 5 ret = ret & btlib.connect_test(clis) 6 ret = ret & btlib.jabber_login_test(clis) 7 ret = ret & btlib.add_buddy_test(clis) 8 ret = ret & btlib.message_test(clis) 125 9 return ret 126 10 127 def add_buddy_test(clis): 128 clis[0].add_jabber_buddy(clis[1].nick) 129 clis[1].send_priv_msg("&bitlbee", "yes") 130 131 clis[1].add_jabber_buddy(clis[0].nick) 132 clis[0].send_priv_msg("&bitlbee", "yes") 133 134 clis[0].send_priv_msg("&bitlbee", "blist") 135 junk = clis[0].receive() 136 ret = junk.find(clis[1].nick) != -1 137 ret = ret & (junk.find("1 available") != -1) 138 ''' 139 clis[0].send_priv_msg("&bitlbee", "remove " +clis[1].nick) 140 clis[0].send_priv_msg("&bitlbee", "blist") 141 ret = ret & (clis[0].receive().find(clis[1].nick) == -1) 142 143 clis[0].add_jabber_buddy(clis[1].nick) 144 clis[1].send_priv_msg("&bitlbee", "yes") 145 time.sleep(1) 146 clis[0].send_priv_msg("&bitlbee", "blist") 147 junk = clis[0].receive() 148 ret = ret & (junk.find("1 available") != -1) 149 ret = ret & (junk.find(clis[1].nick) != -1) 150 ''' 151 return ret 152 153 def message_test(clis): 154 ret = msg_comes_thru(clis[0], clis[1], 'ohai <3') 155 ret = ret & msg_comes_thru(clis[1], clis[0], 'uwu *pounces*') 156 return ret 157 158 def block_test(clis): 159 clis[0].block_jabber_buddy(clis[1].nick) 160 ret = not msg_comes_thru(clis[1], clis[0], 'm-meow?') 161 clis[0].unblock_jabber_buddy(clis[1].nick) 162 ret = ret & msg_comes_thru(clis[1], clis[0], '*purrs*') 163 return ret 164 165 def rename_test(clis): 166 newname = "xXx_pup_LINKENPARK4EVA" 167 message = "rawr meanmz i luv<3 u in dinosaur" 168 169 clis[0].rename_jabber_buddy(clis[1].nick, newname) 170 clis[0].send_priv_msg(newname, message) 171 ret = clis[1].receive().find(message) != -1 172 173 clis[0].rename_jabber_buddy("-del", newname) 174 ret = ret & msg_comes_thru(clis[0], clis[1], "rawr") 175 return ret 176 177 def status_test(clis): 178 status = "get out of my room mom" 179 clis[1].send_priv_msg("&bitlbee", "set status '"+status+"'") 180 clis[0].send_priv_msg("&bitlbee", "info "+clis[1].nick) 181 ret = (clis[0].receive().find("jabber - Status message: "+status) != -1) 182 183 clis[1].send_priv_msg("&bitlbee", "set") 184 ret = ret & (clis[1].receive().find(status) != -1) 185 186 clis[1].send_priv_msg("&bitlbee", "set -del status") 187 clis[0].send_priv_msg("&bitlbee", "info "+clis[1].nick) 188 ret = ret & (clis[0].receive().find("jabber - Status message: (none)") != -1) 189 return ret 190 191 def offline_test(clis): 192 clis[0].send_priv_msg("&bitlbee", "account off") 193 194 junk = clis[0].receive() 195 ret = (junk.find(clis[1].nick) != -1) 196 ret = ret & (junk.find("QUIT") != -1) 197 198 junk = clis[1].receive() 199 ret = ret & (junk.find(clis[0].nick) != -1) 200 ret = ret & (junk.find("QUIT") != -1) 201 202 clis[0].send_priv_msg(clis[1].nick, "i'm not ur mom") 203 ret = ret & (clis[0].receive().find("No such nick/channel") != -1) 204 205 clis[0].send_priv_msg("&bitlbee", "account on") 206 207 junk = clis[0].receive() 208 ret = ret & (junk.find(clis[1].nick) != -1) 209 ret = ret & (junk.find("JOIN") != -1) 210 211 junk = clis[1].receive() 212 ret = ret & (junk.find(clis[0].nick) != -1) 213 ret = ret & (junk.find("JOIN") != -1) 214 215 return ret 216 217 def default_target_test(clis): 218 clis[0].send_priv_msg("&bitlbee", "set default_target last") 219 clis[0].send_priv_msg("&bitlbee", "test2: ur mah default now") 220 221 ret = (clis[1].receive().find("ur mah default now") != -1) 222 223 clis[0].send_priv_msg("&bitlbee", "mrow") 224 ret = ret & (clis[1].receive().find("mrow") != -1) 225 226 clis[0].send_priv_msg("root", "set default_target root") 227 junk = clis[0].receive() 228 ret = ret & (junk.find("default_target") != -1) 229 ret = ret & (junk.find("root") != -1) 230 231 clis[0].send_priv_msg("&bitlbee", "yes") 232 ret = ret & (clis[1].receive().find("yes") == -1) 233 return ret 234 235 def help_test(clis): 236 clis[0].send_priv_msg("&bitlbee", "help") 237 ret = (clis[0].receive().find("identify_methods") != -1) 238 clis[0].send_priv_msg("&bitlbee", "help commands") 239 ret = ret & (clis[0].receive().find("qlist") != -1) 240 return ret 241 242 def run_tests(failed): 243 clis = [] 244 clis += [IrcClient('test1', 'asd')] 245 clis += [IrcClient('test2', 'asd')] 246 for cli in clis: 247 cli.connect() 248 249 perform_test(failed, clis, yes_test, "Yes", debug_file) 250 251 print("") 252 for cli in clis: 253 cli.jabber_login() 254 255 perform_test(failed, clis, add_buddy_test, "Add/remove buddy") 256 perform_test(failed, clis, message_test, "Send message") 257 #perform_test(failed, clis, block_test, "Block user", debug_file) 258 perform_test(failed, clis, rename_test, "Rename user") 259 perform_test(failed, clis, status_test, "Change status") 260 perform_test(failed, clis, offline_test, "Go offline") 261 perform_test(failed, clis, default_target_test, "Change default target") 262 perform_test(failed, clis, help_test, "Ask for help") 263 264 if failed or SHOWLOG: 265 print("") 266 for cli in clis: 267 print(SMOLPARATOR) 268 print("Log "+ cli.nick+":") 269 print(cli.log) 270 print(SMOLPARATOR) 271 272 if failed: 273 print("\n" + SEPARATOR + "\nSome test have failed:") 274 for fail in failed: 275 print(fail) 276 else: 277 print("\n" + SEPARATOR + "\nAll tests have passed") 278 279 if __name__ == "__main__": 280 failed = [] 281 run_tests(failed) 282 if failed: 283 sys.exit(1) 11 btlib.perform_test(send_msg)
Note: See TracChangeset
for help on using the changeset viewer.