Changeset e14bdc67


Ignore:
Timestamp:
2021-03-29T13:14:39Z (3 years ago)
Author:
/ <>
Children:
ef70f9f
Parents:
f7cd819
Message:

some more

Files:
3 added
3 edited

Legend:

Unmodified
Added
Removed
  • .github/workflows/ci.yml

    rf7cd819 re14bdc67  
    4343        ./.tests/cleanup_prosody.sh
    4444
     45    - name: jabber add buddy
     46      run: |
     47        ./.tests/setup_prosody.sh
     48        ./.tests/setup_bitlbee.sh
     49
     50        python3 ./.tests/jabber_add_buddy.py
     51
     52        ./.tests/cleanup_bitlbee.sh
     53        ./.tests/cleanup_prosody.sh
     54
     55    - name: jabber send message
     56      run: |
     57        ./.tests/setup_prosody.sh
     58        ./.tests/setup_bitlbee.sh
     59
     60        python3 ./.tests/jabber_send_msg.py
     61
     62        ./.tests/cleanup_bitlbee.sh
     63        ./.tests/cleanup_prosody.sh
     64
     65    - name: jabber rename buddy
     66      run: |
     67        ./.tests/setup_prosody.sh
     68        ./.tests/setup_bitlbee.sh
     69
     70        python3 ./.tests/jabber_rename_buddy.py
     71
     72        ./.tests/cleanup_bitlbee.sh
     73        ./.tests/cleanup_prosody.sh
     74
     75    - name: jabber set status
     76      run: |
     77        ./.tests/setup_prosody.sh
     78        ./.tests/setup_bitlbee.sh
     79
     80        python3 ./.tests/jabber_status.py
     81
     82        ./.tests/cleanup_bitlbee.sh
     83        ./.tests/cleanup_prosody.sh
     84
    4585    - name: code coverage
    4686      if: ${{ always() }}
  • .tests/cleanup_bitlbee.sh

    rf7cd819 re14bdc67  
    55killall bitlbee
    66
    7 printf '\n\nBitlbee output:\n\n'
     7printf 'Bitlbee output:\n\n'
    88less ./debuglog
    99
  • .tests/jabber_send_msg.py

    rf7cd819 re14bdc67  
    1 import socket
    2 import sys
    3 import time
    4 import select
     1import btlib
    52
    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
     3def 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)
    1259    return ret
    12610
    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)
     11btlib.perform_test(send_msg)
Note: See TracChangeset for help on using the changeset viewer.