mirror of
https://github.com/google/alertmanager-irc-relay.git
synced 2025-01-27 21:04:04 +01:00
try to unban ourselves before joining a channel
Signed-off-by: Luca Bigliardi <shammash@google.com>
This commit is contained in:
parent
f73a0bfdf0
commit
9748c8bfbf
13
irc_test.go
13
irc_test.go
@ -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",
|
||||||
}
|
}
|
||||||
|
@ -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)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user