try to unban ourselves before joining a channel

Signed-off-by: Luca Bigliardi <shammash@google.com>
This commit is contained in:
Luca Bigliardi 2021-04-16 13:53:06 +02:00
parent f73a0bfdf0
commit 9748c8bfbf
2 changed files with 15 additions and 1 deletions

View File

@ -88,12 +88,13 @@ func TestServerPassword(t *testing.T) {
"PASS hostsecret", "PASS hostsecret",
"NICK foo", "NICK foo",
"USER foo 12 * :", "USER foo 12 * :",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
"QUIT :see ya", "QUIT :see ya",
} }
if !reflect.DeepEqual(expectedCommands, server.Log) { if !reflect.DeepEqual(expectedCommands, server.Log) {
t.Error("Did not send IRC server password") t.Error("Did not send IRC server password. Received commands:\n", strings.Join(server.Log, "\n"))
} }
} }
@ -143,6 +144,7 @@ func TestSendAlertOnPreJoinedChannel(t *testing.T) {
expectedCommands := []string{ expectedCommands := []string{
"NICK foo", "NICK foo",
"USER foo 12 * :", "USER foo 12 * :",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
"NOTICE #foo :test message", "NOTICE #foo :test message",
"QUIT :see ya", "QUIT :see ya",
@ -200,6 +202,7 @@ func TestUsePrivmsgToSendAlertOnPreJoinedChannel(t *testing.T) {
expectedCommands := []string{ expectedCommands := []string{
"NICK foo", "NICK foo",
"USER foo 12 * :", "USER foo 12 * :",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
"PRIVMSG #foo :test message", "PRIVMSG #foo :test message",
"QUIT :see ya", "QUIT :see ya",
@ -254,8 +257,10 @@ func TestSendAlertAndJoinChannel(t *testing.T) {
expectedCommands := []string{ expectedCommands := []string{
"NICK foo", "NICK foo",
"USER foo 12 * :", "USER foo 12 * :",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
// #foobar joined before sending message // #foobar joined before sending message
"PRIVMSG ChanServ :UNBAN #foobar",
"JOIN #foobar", "JOIN #foobar",
"NOTICE #foobar :test message", "NOTICE #foobar :test message",
"QUIT :see ya", "QUIT :see ya",
@ -332,6 +337,7 @@ func TestSendAlertDisconnected(t *testing.T) {
expectedCommands := []string{ expectedCommands := []string{
"NICK foo", "NICK foo",
"USER foo 12 * :", "USER foo 12 * :",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
// Only message sent while being connected is received. // Only message sent while being connected is received.
"NOTICE #foo :connected test message", "NOTICE #foo :connected test message",
@ -378,10 +384,12 @@ func TestReconnect(t *testing.T) {
// Commands from first connection // Commands from first connection
"NICK foo", "NICK foo",
"USER foo 12 * :", "USER foo 12 * :",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
// Commands from reconnection // Commands from reconnection
"NICK foo", "NICK foo",
"USER foo 12 * :", "USER foo 12 * :",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
"QUIT :see ya", "QUIT :see ya",
} }
@ -441,6 +449,7 @@ func TestConnectErrorRetry(t *testing.T) {
expectedCommands := []string{ expectedCommands := []string{
"NICK foo", "NICK foo",
"USER foo 12 * :", "USER foo 12 * :",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
"QUIT :see ya", "QUIT :see ya",
} }
@ -481,6 +490,7 @@ func TestIdentify(t *testing.T) {
"NICK foo", "NICK foo",
"USER foo 12 * :", "USER foo 12 * :",
"PRIVMSG NickServ :IDENTIFY nickpassword", "PRIVMSG NickServ :IDENTIFY nickpassword",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
"QUIT :see ya", "QUIT :see ya",
} }
@ -544,6 +554,7 @@ func TestGhostAndIdentify(t *testing.T) {
"PRIVMSG NickServ :GHOST foo nickpassword", "PRIVMSG NickServ :GHOST foo nickpassword",
"NICK foo", "NICK foo",
"PRIVMSG NickServ :IDENTIFY nickpassword", "PRIVMSG NickServ :IDENTIFY nickpassword",
"PRIVMSG ChanServ :UNBAN #foo",
"JOIN #foo", "JOIN #foo",
"QUIT :see ya", "QUIT :see ya",
} }

View File

@ -105,6 +105,9 @@ func (c *channelState) join(ctx context.Context) {
return return
} }
// Try to unban ourselves, just in case
c.client.Privmsgf("ChanServ", "UNBAN %s", c.channel.Name)
c.client.Join(c.channel.Name, c.channel.Password) c.client.Join(c.channel.Name, c.channel.Password)
logging.Info("Channel %s monitor: join request sent", c.channel.Name) logging.Info("Channel %s monitor: join request sent", c.channel.Name)