mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-10-31 08:11:32 +01:00 
			
		
		
		
	This updates all source files to use a new standard header for copyright and license declaration. Notably, copyright no longer includes a date, and we now use the standard SPDX-License-Identifier header. This commit was done almost entirely mechanically with perl, and then some minimal manual fixes. Updates #6865 Signed-off-by: Will Norris <will@tailscale.com>
		
			
				
	
	
		
			78 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright (c) Tailscale Inc & AUTHORS
 | |
| // SPDX-License-Identifier: BSD-3-Clause
 | |
| 
 | |
| //go:build ignore
 | |
| 
 | |
| // Command udp_tester exists because all of these distros being tested don't
 | |
| // have a consistent tool for doing UDP traffic. This is a very hacked up tool
 | |
| // that does that UDP traffic so these tests can be done.
 | |
| package main
 | |
| 
 | |
| import (
 | |
| 	"flag"
 | |
| 	"io"
 | |
| 	"log"
 | |
| 	"net"
 | |
| 	"os"
 | |
| )
 | |
| 
 | |
| var (
 | |
| 	client = flag.String("client", "", "host:port to connect to for sending UDP")
 | |
| 	server = flag.String("server", "", "host:port to bind to for receiving UDP")
 | |
| )
 | |
| 
 | |
| func main() {
 | |
| 	flag.Parse()
 | |
| 
 | |
| 	if *client == "" && *server == "" {
 | |
| 		log.Fatal("specify -client or -server")
 | |
| 	}
 | |
| 
 | |
| 	if *client != "" {
 | |
| 		conn, err := net.Dial("udp", *client)
 | |
| 		if err != nil {
 | |
| 			log.Fatalf("can't dial %s: %v", *client, err)
 | |
| 		}
 | |
| 		log.Printf("dialed to %s", conn.RemoteAddr())
 | |
| 		defer conn.Close()
 | |
| 
 | |
| 		buf := make([]byte, 2048)
 | |
| 		n, err := os.Stdin.Read(buf)
 | |
| 		if err != nil && err != io.EOF {
 | |
| 			log.Fatalf("can't read from stdin: %v", err)
 | |
| 		}
 | |
| 
 | |
| 		nn, err := conn.Write(buf[:n])
 | |
| 		if err != nil {
 | |
| 			log.Fatalf("can't write to %s: %v", conn.RemoteAddr(), err)
 | |
| 		}
 | |
| 
 | |
| 		if n == nn {
 | |
| 			return
 | |
| 		}
 | |
| 
 | |
| 		log.Fatalf("wanted to write %d bytes, wrote %d bytes", n, nn)
 | |
| 	}
 | |
| 
 | |
| 	if *server != "" {
 | |
| 		addr, err := net.ResolveUDPAddr("udp", *server)
 | |
| 		if err != nil {
 | |
| 			log.Fatalf("can't resolve %s: %v", *server, err)
 | |
| 		}
 | |
| 		ln, err := net.ListenUDP("udp", addr)
 | |
| 		if err != nil {
 | |
| 			log.Fatalf("can't listen %s: %v", *server, err)
 | |
| 		}
 | |
| 		defer ln.Close()
 | |
| 
 | |
| 		buf := make([]byte, 2048)
 | |
| 
 | |
| 		n, _, err := ln.ReadFromUDP(buf)
 | |
| 		if err != nil {
 | |
| 			log.Fatal(err)
 | |
| 		}
 | |
| 
 | |
| 		os.Stdout.Write(buf[:n])
 | |
| 	}
 | |
| }
 |