| 
									
										
										
										
											2023-01-27 13:37:20 -08:00
										 |  |  | // Copyright (c) Tailscale Inc & AUTHORS | 
					
						
							|  |  |  | // SPDX-License-Identifier: BSD-3-Clause | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | package wglog_test | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"testing" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-27 17:42:33 -07:00
										 |  |  | 	"go4.org/mem" | 
					
						
							|  |  |  | 	"tailscale.com/types/key" | 
					
						
							| 
									
										
										
										
											2021-05-11 12:09:51 -07:00
										 |  |  | 	"tailscale.com/types/logger" | 
					
						
							| 
									
										
										
										
											2021-01-29 12:16:36 -08:00
										 |  |  | 	"tailscale.com/wgengine/wgcfg" | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 	"tailscale.com/wgengine/wglog" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func TestLogger(t *testing.T) { | 
					
						
							|  |  |  | 	tests := []struct { | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 		format string | 
					
						
							| 
									
										
										
										
											2022-03-16 16:27:57 -07:00
										 |  |  | 		args   []any | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 		want   string | 
					
						
							|  |  |  | 		omit   bool | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 	}{ | 
					
						
							| 
									
										
										
										
											2023-01-23 14:05:33 -08:00
										 |  |  | 		{"hi", nil, "wg: hi", false}, | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 		{"Routine: starting", nil, "", true}, | 
					
						
							| 
									
										
										
										
											2023-01-23 14:05:33 -08:00
										 |  |  | 		{"%v says it misses you", []any{stringer("peer(IMTB…r7lM)")}, "wg: [IMTBr] says it misses you", false}, | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 	type log struct { | 
					
						
							|  |  |  | 		format string | 
					
						
							| 
									
										
										
										
											2022-03-16 16:27:57 -07:00
										 |  |  | 		args   []any | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	c := make(chan log, 1) | 
					
						
							| 
									
										
										
										
											2022-03-16 16:27:57 -07:00
										 |  |  | 	logf := func(format string, args ...any) { | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 		select { | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 		case c <- log{format, args}: | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 		default: | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 			t.Errorf("wrote %q, but shouldn't have", fmt.Sprintf(format, args...)) | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	x := wglog.NewLogger(logf) | 
					
						
							| 
									
										
										
										
											2021-10-27 17:42:33 -07:00
										 |  |  | 	key, err := key.ParseNodePublicUntyped(mem.S("20c4c1ae54e1fd37cab6e9a532ca20646aff496796cc41d4519560e5e82bee53")) | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		t.Fatal(err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	x.SetPeers([]wgcfg.Peer{{PublicKey: key}}) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for _, tt := range tests { | 
					
						
							|  |  |  | 		if tt.omit { | 
					
						
							|  |  |  | 			// Write a message ourselves into the channel. | 
					
						
							|  |  |  | 			// Then if logf also attempts to write into the channel, it'll fail. | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 			c <- log{} | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 		x.DeviceLogger.Errorf(tt.format, tt.args...) | 
					
						
							|  |  |  | 		gotLog := <-c | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 		if tt.omit { | 
					
						
							|  |  |  | 			continue | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 		if got := fmt.Sprintf(gotLog.format, gotLog.args...); got != tt.want { | 
					
						
							|  |  |  | 			t.Errorf("Printf(%q, %v) = %q want %q", tt.format, tt.args, got, tt.want) | 
					
						
							| 
									
										
										
										
											2021-01-21 12:33:54 -08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-23 09:38:25 -08:00
										 |  |  | func TestSuppressLogs(t *testing.T) { | 
					
						
							|  |  |  | 	var logs []string | 
					
						
							|  |  |  | 	logf := func(format string, args ...any) { | 
					
						
							|  |  |  | 		logs = append(logs, fmt.Sprintf(format, args...)) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	x := wglog.NewLogger(logf) | 
					
						
							|  |  |  | 	x.DeviceLogger.Verbosef("pass") | 
					
						
							|  |  |  | 	x.DeviceLogger.Verbosef("UAPI: Adding allowedip") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if len(logs) != 1 { | 
					
						
							|  |  |  | 		t.Fatalf("got %d logs, want 1", len(logs)) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if logs[0] != "wg: [v2] pass" { | 
					
						
							|  |  |  | 		t.Errorf("got %q, want \"wg: [v2] pass\"", logs[0]) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-04-27 10:03:13 -07:00
										 |  |  | func stringer(s string) stringerString { | 
					
						
							|  |  |  | 	return stringerString(s) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type stringerString string | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func (s stringerString) String() string { return string(s) } | 
					
						
							| 
									
										
										
										
											2021-05-11 12:09:51 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | func BenchmarkSetPeers(b *testing.B) { | 
					
						
							|  |  |  | 	b.ReportAllocs() | 
					
						
							|  |  |  | 	x := wglog.NewLogger(logger.Discard) | 
					
						
							|  |  |  | 	peers := [][]wgcfg.Peer{genPeers(0), genPeers(15), genPeers(16), genPeers(15)} | 
					
						
							| 
									
										
										
										
											2024-04-16 13:15:13 -07:00
										 |  |  | 	for range b.N { | 
					
						
							| 
									
										
										
										
											2021-05-11 12:09:51 -07:00
										 |  |  | 		for _, p := range peers { | 
					
						
							|  |  |  | 			x.SetPeers(p) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func genPeers(n int) []wgcfg.Peer { | 
					
						
							|  |  |  | 	if n > 32 { | 
					
						
							|  |  |  | 		panic("too many peers") | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if n == 0 { | 
					
						
							|  |  |  | 		return nil | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	peers := make([]wgcfg.Peer, n) | 
					
						
							|  |  |  | 	for i := range peers { | 
					
						
							| 
									
										
										
										
											2021-10-27 17:42:33 -07:00
										 |  |  | 		var k [32]byte | 
					
						
							| 
									
										
										
										
											2021-05-11 12:09:51 -07:00
										 |  |  | 		k[n] = byte(n) | 
					
						
							| 
									
										
										
										
											2021-10-27 17:42:33 -07:00
										 |  |  | 		peers[i].PublicKey = key.NodePublicFromRaw32(mem.B(k[:])) | 
					
						
							| 
									
										
										
										
											2021-05-11 12:09:51 -07:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return peers | 
					
						
							|  |  |  | } |