mirror of
https://github.com/tailscale/tailscale.git
synced 2024-12-04 23:45:34 +00:00
5a44f9f5b5
While we rearrange/upstream things.
gliderlabs/ssh is forked into tempfork from our prior fork
at be8b7add40
x/crypto/ssh OTOH is forked at
https://github.com/tailscale/golang-x-crypto because it was gnarlier
to vendor with various internal packages, etc.
Its git history shows where it starts (2c7772ba30643b7a2026cbea938420dce7c6384d).
Updates #3802
Change-Id: I546e5cdf831cfc030a6c42557c0ad2c58766c65f
Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
51 lines
1.1 KiB
Go
51 lines
1.1 KiB
Go
//go:build glidertests
|
|
// +build glidertests
|
|
|
|
package ssh
|
|
|
|
import "testing"
|
|
|
|
func TestSetPermissions(t *testing.T) {
|
|
t.Parallel()
|
|
permsExt := map[string]string{
|
|
"foo": "bar",
|
|
}
|
|
session, _, cleanup := newTestSessionWithOptions(t, &Server{
|
|
Handler: func(s Session) {
|
|
if _, ok := s.Permissions().Extensions["foo"]; !ok {
|
|
t.Fatalf("got %#v; want %#v", s.Permissions().Extensions, permsExt)
|
|
}
|
|
},
|
|
}, nil, PasswordAuth(func(ctx Context, password string) bool {
|
|
ctx.Permissions().Extensions = permsExt
|
|
return true
|
|
}))
|
|
defer cleanup()
|
|
if err := session.Run(""); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|
|
|
|
func TestSetValue(t *testing.T) {
|
|
t.Parallel()
|
|
value := map[string]string{
|
|
"foo": "bar",
|
|
}
|
|
key := "testValue"
|
|
session, _, cleanup := newTestSessionWithOptions(t, &Server{
|
|
Handler: func(s Session) {
|
|
v := s.Context().Value(key).(map[string]string)
|
|
if v["foo"] != value["foo"] {
|
|
t.Fatalf("got %#v; want %#v", v, value)
|
|
}
|
|
},
|
|
}, nil, PasswordAuth(func(ctx Context, password string) bool {
|
|
ctx.SetValue(key, value)
|
|
return true
|
|
}))
|
|
defer cleanup()
|
|
if err := session.Run(""); err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
}
|