mirror of
https://github.com/progval/irctest.git
synced 2025-04-06 07:19:54 +00:00
rough test for bouncer functionality
This commit is contained in:
@ -55,6 +55,10 @@ accounts:
|
|||||||
|
|
||||||
authentication-enabled: true
|
authentication-enabled: true
|
||||||
|
|
||||||
|
bouncer:
|
||||||
|
enabled: true
|
||||||
|
allowed-by-default: false
|
||||||
|
|
||||||
channels:
|
channels:
|
||||||
registration:
|
registration:
|
||||||
enabled: true
|
enabled: true
|
||||||
|
@ -14,7 +14,7 @@ unescape_tag_value = supybot.utils.str.MultipleReplacer(
|
|||||||
dict(map(lambda x:(x[1],x[0]), TAG_ESCAPE)))
|
dict(map(lambda x:(x[1],x[0]), TAG_ESCAPE)))
|
||||||
|
|
||||||
# TODO: validate host
|
# TODO: validate host
|
||||||
tag_key_validator = re.compile('(\S+/)?[a-zA-Z0-9-]+')
|
tag_key_validator = re.compile(r'\+?(\S+/)?[a-zA-Z0-9-]+')
|
||||||
|
|
||||||
def parse_tags(s):
|
def parse_tags(s):
|
||||||
tags = {}
|
tags = {}
|
||||||
|
108
irctest/server_tests/test_bouncer.py
Normal file
108
irctest/server_tests/test_bouncer.py
Normal file
@ -0,0 +1,108 @@
|
|||||||
|
from irctest import cases
|
||||||
|
from irctest.irc_utils.sasl import sasl_plain_blob
|
||||||
|
|
||||||
|
from irctest.numerics import RPL_WELCOME
|
||||||
|
from irctest.numerics import ERR_NICKNAMEINUSE
|
||||||
|
|
||||||
|
class Bouncer(cases.BaseServerTestCase):
|
||||||
|
|
||||||
|
@cases.SpecificationSelector.requiredBySpecification('Oragono')
|
||||||
|
def testBouncer(self):
|
||||||
|
"""Test basic bouncer functionality."""
|
||||||
|
self.controller.registerUser(self, 'observer', 'observerpassword')
|
||||||
|
self.controller.registerUser(self, 'testuser', 'mypassword')
|
||||||
|
|
||||||
|
self.connectClient('observer')
|
||||||
|
self.joinChannel(1, '#chan')
|
||||||
|
self.sendLine(1, 'NICKSERV IDENTIFY observer observerpassword')
|
||||||
|
self.getMessages(1)
|
||||||
|
|
||||||
|
self.addClient()
|
||||||
|
self.sendLine(2, 'CAP LS 302')
|
||||||
|
self.sendLine(2, 'AUTHENTICATE PLAIN')
|
||||||
|
self.sendLine(2, sasl_plain_blob('testuser', 'mypassword'))
|
||||||
|
self.sendLine(2, 'NICK testnick')
|
||||||
|
self.sendLine(2, 'USER a 0 * a')
|
||||||
|
self.sendLine(2, 'CAP REQ :server-time message-tags oragono.io/bnc')
|
||||||
|
self.sendLine(2, 'CAP END')
|
||||||
|
messages = self.getMessages(2)
|
||||||
|
welcomes = [message for message in messages if message.command == RPL_WELCOME]
|
||||||
|
self.assertEqual(len(welcomes), 1)
|
||||||
|
# should see a regburst for testnick
|
||||||
|
self.assertEqual(welcomes[0].params[0], 'testnick')
|
||||||
|
self.joinChannel(2, '#chan')
|
||||||
|
|
||||||
|
self.addClient()
|
||||||
|
self.sendLine(3, 'CAP LS 302')
|
||||||
|
self.sendLine(3, 'AUTHENTICATE PLAIN')
|
||||||
|
self.sendLine(3, sasl_plain_blob('testuser', 'mypassword'))
|
||||||
|
self.sendLine(3, 'NICK testnick')
|
||||||
|
self.sendLine(3, 'USER a 0 * a')
|
||||||
|
self.sendLine(3, 'CAP REQ :server-time message-tags account-tag oragono.io/bnc')
|
||||||
|
self.sendLine(3, 'CAP END')
|
||||||
|
messages = self.getMessages(3)
|
||||||
|
welcomes = [message for message in messages if message.command == RPL_WELCOME]
|
||||||
|
self.assertEqual(len(welcomes), 1)
|
||||||
|
# should see the *same* regburst for testnick
|
||||||
|
self.assertEqual(welcomes[0].params[0], 'testnick')
|
||||||
|
joins = [message for message in messages if message.command == 'JOIN']
|
||||||
|
# we should be automatically joined to #chan
|
||||||
|
self.assertEqual(joins[0].params[0], '#chan')
|
||||||
|
|
||||||
|
self.addClient()
|
||||||
|
self.sendLine(4, 'CAP LS 302')
|
||||||
|
self.sendLine(4, 'AUTHENTICATE PLAIN')
|
||||||
|
self.sendLine(4, sasl_plain_blob('testuser', 'mypassword'))
|
||||||
|
self.sendLine(4, 'NICK testnick')
|
||||||
|
self.sendLine(4, 'USER a 0 * a')
|
||||||
|
self.sendLine(4, 'CAP REQ :server-time message-tags')
|
||||||
|
self.sendLine(4, 'CAP END')
|
||||||
|
# without the bnc cap, we should not be able to attach to the nick
|
||||||
|
messages = self.getMessages(4)
|
||||||
|
welcomes = [message for message in messages if message.command == RPL_WELCOME]
|
||||||
|
self.assertEqual(len(welcomes), 0)
|
||||||
|
errors = [message for message in messages if message.command == ERR_NICKNAMEINUSE]
|
||||||
|
self.assertEqual(len(errors), 1)
|
||||||
|
|
||||||
|
self.sendLine(1, '@+clientOnlyTag=Value PRIVMSG #chan :hey')
|
||||||
|
self.getMessages(1)
|
||||||
|
messagesfortwo = [msg for msg in self.getMessages(2) if msg.command == 'PRIVMSG']
|
||||||
|
messagesforthree = [msg for msg in self.getMessages(3) if msg.command == 'PRIVMSG']
|
||||||
|
self.assertEqual(len(messagesfortwo), 1)
|
||||||
|
self.assertEqual(len(messagesforthree), 1)
|
||||||
|
messagefortwo = messagesfortwo[0]
|
||||||
|
messageforthree = messagesforthree[0]
|
||||||
|
self.assertEqual(messagefortwo.params, ['#chan', 'hey'])
|
||||||
|
self.assertEqual(messageforthree.params, ['#chan', 'hey'])
|
||||||
|
# TODO assert equality of the msgids
|
||||||
|
self.assertIn('time', messagefortwo.tags)
|
||||||
|
self.assertNotIn('account', messagefortwo.tags)
|
||||||
|
self.assertIn('time', messageforthree.tags)
|
||||||
|
# 3 has account-tag, 2 doesn't
|
||||||
|
self.assertIn('account', messageforthree.tags)
|
||||||
|
|
||||||
|
self.sendLine(2, 'QUIT :two out')
|
||||||
|
quitLines = [msg for msg in self.getMessages(2) if msg.command == 'QUIT']
|
||||||
|
self.assertEqual(len(quitLines), 1)
|
||||||
|
self.assertIn('two out', quitLines[0].params[0])
|
||||||
|
# neither the observer nor the other attached session should see a quit here
|
||||||
|
quitLines = [msg for msg in self.getMessages(1) if msg.command == 'QUIT']
|
||||||
|
self.assertEqual(quitLines, [])
|
||||||
|
quitLines = [msg for msg in self.getMessages(3) if msg.command == 'QUIT']
|
||||||
|
self.assertEqual(quitLines, [])
|
||||||
|
|
||||||
|
# session 3 should be untouched at this point
|
||||||
|
self.sendLine(1, '@+clientOnlyTag=Value PRIVMSG #chan :hey again')
|
||||||
|
self.getMessages(1)
|
||||||
|
messagesforthree = [msg for msg in self.getMessages(3) if msg.command == 'PRIVMSG']
|
||||||
|
self.assertEqual(len(messagesforthree), 1)
|
||||||
|
self.assertMessageEqual(messagesforthree[0], command='PRIVMSG', params=['#chan', 'hey again'])
|
||||||
|
|
||||||
|
self.sendLine(3, 'QUIT :three out')
|
||||||
|
quitLines = [msg for msg in self.getMessages(3) if msg.command == 'QUIT']
|
||||||
|
self.assertEqual(len(quitLines), 1)
|
||||||
|
self.assertIn('three out', quitLines[0].params[0])
|
||||||
|
# observer should see *this* quit
|
||||||
|
quitLines = [msg for msg in self.getMessages(1) if msg.command == 'QUIT']
|
||||||
|
self.assertEqual(len(quitLines), 1)
|
||||||
|
self.assertIn('three out', quitLines[0].params[0])
|
Reference in New Issue
Block a user