]> Cypherpunks.ru repositories - goircd.git/blobdiff - common_test.go
Unify copyright comment format
[goircd.git] / common_test.go
index 5040018c7394b576e9b9a985a26358d5a890ce45..c6a2f3b4f723ec78a0eba9e6299490a538339cae 100644 (file)
@@ -1,40 +1,38 @@
-/*
-goircd -- minimalistic simple Internet Relay Chat (IRC) server
-Copyright (C) 2014-2018 | wn Sergey Matveev <stargrave@stargrave.org>
-
-This program is free software: you can redistribute it and/or modify
-it under the terms of the GNU General Public License as published by
-the Free Software Foundation, either version 3 of the License, or
-(at your option) any later version.
-
-This program is distributed in the hope that it will be useful,
-but WITHOUT ANY WARRANTY; without even the implied warranty of
-MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-GNU General Public License for more details.
-
-You should have received a copy of the GNU General Public License
-along with this program.  If not, see <http://www.gnu.org/licenses/>.
-*/
+// goircd -- minimalistic simple Internet Relay Chat (IRC) server
+// Copyright (C) 2014-2024 Sergey Matveev <stargrave@stargrave.org>
+//
+// This program is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation, version 3 of the License.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program.  If not, see <http://www.gnu.org/licenses/>.
 
 package main
 
 import (
+       "io"
        "net"
        "time"
 )
 
-// Testing network connection that satisfies net.Conn interface
-// Can send predefined messages and store all written ones
 type TestingConn struct {
        inbound  chan string
        outbound chan string
-       closed   bool
+       closed   chan struct{}
 }
 
 func NewTestingConn() *TestingConn {
-       inbound := make(chan string, 8)
-       outbound := make(chan string, 8)
-       return &TestingConn{inbound: inbound, outbound: outbound}
+       return &TestingConn{
+               inbound:  make(chan string, 8),
+               outbound: make(chan string, 8),
+               closed:   make(chan struct{}),
+       }
 }
 
 func (conn TestingConn) Error() string {
@@ -42,14 +40,18 @@ func (conn TestingConn) Error() string {
 }
 
 func (conn *TestingConn) Read(b []byte) (n int, err error) {
-       msg := <-conn.inbound
-       if msg == "" {
-               return 0, conn
-       }
-       for n, bt := range append([]byte(msg), CRLF...) {
-               b[n] = bt
+       select {
+       case msg := <-conn.inbound:
+               if msg == "" {
+                       return 0, conn
+               }
+               for n, bt := range append([]byte(msg), CRLF...) {
+                       b[n] = bt
+               }
+               return len(msg) + 2, nil
+       case <-conn.closed:
+               return 0, io.EOF
        }
-       return len(msg) + 2, nil
 }
 
 type MyAddr struct{}
@@ -67,7 +69,7 @@ func (conn *TestingConn) Write(b []byte) (n int, err error) {
 }
 
 func (conn *TestingConn) Close() error {
-       conn.closed = true
+       close(conn.closed)
        close(conn.outbound)
        return nil
 }