mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-10-26 02:29:28 +00:00 
			
		
		
		
	 e9505e5432
			
		
	
	e9505e5432
	
	
	
		
			
			Setting the field after-the-fact wasn't working because we could migrate prefs on creation, which would set health status for auto updates. Updates #11986 Signed-off-by: Andrew Dunham <andrew@du.nham.ca> Change-Id: I41d79ebd61d64829a3a9e70586ce56f62d24ccfd
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright (c) Tailscale Inc & AUTHORS
 | |
| // SPDX-License-Identifier: BSD-3-Clause
 | |
| 
 | |
| //go:build linux || (darwin && !ios)
 | |
| 
 | |
| package ipnlocal
 | |
| 
 | |
| import (
 | |
| 	"encoding/json"
 | |
| 	"reflect"
 | |
| 	"testing"
 | |
| 
 | |
| 	"tailscale.com/health"
 | |
| 	"tailscale.com/ipn/store/mem"
 | |
| 	"tailscale.com/tailcfg"
 | |
| 	"tailscale.com/util/must"
 | |
| )
 | |
| 
 | |
| func TestSSHKeyGen(t *testing.T) {
 | |
| 	dir := t.TempDir()
 | |
| 	lb := &LocalBackend{varRoot: dir}
 | |
| 	keys, err := lb.getTailscaleSSH_HostKeys(nil)
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 	got := map[string]bool{}
 | |
| 	for _, k := range keys {
 | |
| 		got[k.PublicKey().Type()] = true
 | |
| 	}
 | |
| 	want := map[string]bool{
 | |
| 		"ssh-rsa":             true,
 | |
| 		"ecdsa-sha2-nistp256": true,
 | |
| 		"ssh-ed25519":         true,
 | |
| 	}
 | |
| 	if !reflect.DeepEqual(got, want) {
 | |
| 		t.Fatalf("keys = %v; want %v", got, want)
 | |
| 	}
 | |
| 
 | |
| 	keys2, err := lb.getTailscaleSSH_HostKeys(nil)
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 	if !reflect.DeepEqual(keys, keys2) {
 | |
| 		t.Errorf("got different keys on second call")
 | |
| 	}
 | |
| }
 | |
| 
 | |
| type fakeSSHServer struct {
 | |
| 	SSHServer
 | |
| }
 | |
| 
 | |
| func TestGetSSHUsernames(t *testing.T) {
 | |
| 	pm := must.Get(newProfileManager(new(mem.Store), t.Logf, new(health.Tracker)))
 | |
| 	b := &LocalBackend{pm: pm, store: pm.Store()}
 | |
| 	b.sshServer = fakeSSHServer{}
 | |
| 	res, err := b.getSSHUsernames(new(tailcfg.C2NSSHUsernamesRequest))
 | |
| 	if err != nil {
 | |
| 		t.Fatal(err)
 | |
| 	}
 | |
| 	t.Logf("Got: %s", must.Get(json.Marshal(res)))
 | |
| }
 |