Jiri Simsa | d7616c9 | 2015-03-24 23:44:30 -0700 | [diff] [blame] | 1 | // Copyright 2015 The Vanadium Authors. All rights reserved. |
| 2 | // Use of this source code is governed by a BSD-style |
| 3 | // license that can be found in the LICENSE file. |
| 4 | |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 5 | package impl_test |
| 6 | |
| 7 | import ( |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 8 | "io/ioutil" |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 9 | "syscall" |
| 10 | "testing" |
| 11 | |
| 12 | "v.io/v23/context" |
Robert Kroeger | 16ee22b | 2015-03-12 14:57:09 -0700 | [diff] [blame] | 13 | "v.io/v23/naming" |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 14 | "v.io/v23/security" |
Todd Wang | 387d8a4 | 2015-03-30 17:09:05 -0700 | [diff] [blame] | 15 | "v.io/v23/security/access" |
Todd Wang | 30192a2 | 2015-03-31 13:24:41 -0700 | [diff] [blame] | 16 | "v.io/v23/services/permissions" |
Robert Kroeger | 8f914be | 2015-03-14 16:32:37 -0700 | [diff] [blame] | 17 | "v.io/v23/verror" |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 18 | |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 19 | "v.io/x/ref/services/device/internal/impl/utiltest" |
Todd Wang | 5fc3644 | 2015-04-07 15:15:27 -0700 | [diff] [blame] | 20 | "v.io/x/ref/services/internal/servicetest" |
Cosmos Nicolaou | 1381f8a | 2015-03-13 09:40:34 -0700 | [diff] [blame] | 21 | "v.io/x/ref/test/testutil" |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 22 | ) |
| 23 | |
Benjamin Prosnitz | b60efb9 | 2015-03-11 17:47:43 -0700 | [diff] [blame] | 24 | func updateAccessList(t *testing.T, ctx *context.T, blessing, right string, name ...string) { |
Todd Wang | 30192a2 | 2015-03-31 13:24:41 -0700 | [diff] [blame] | 25 | accessStub := permissions.ObjectClient(naming.Join(name...)) |
Adam Sadovsky | a4d4a69 | 2015-04-20 11:36:49 -0700 | [diff] [blame] | 26 | perms, version, err := accessStub.GetPermissions(ctx) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 27 | if err != nil { |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 28 | t.Fatalf(testutil.FormatLogLine(2, "GetPermissions(%v) failed %v", name, err)) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 29 | } |
Adam Sadovsky | a4d4a69 | 2015-04-20 11:36:49 -0700 | [diff] [blame] | 30 | perms.Add(security.BlessingPattern(blessing), right) |
| 31 | if err = accessStub.SetPermissions(ctx, perms, version); err != nil { |
Robert Kroeger | 8f914be | 2015-03-14 16:32:37 -0700 | [diff] [blame] | 32 | t.Fatalf(testutil.FormatLogLine(2, "SetPermissions(%v, %v, %v) failed: %v", name, blessing, right, err)) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 33 | } |
| 34 | } |
| 35 | |
Robert Kroeger | 8f914be | 2015-03-14 16:32:37 -0700 | [diff] [blame] | 36 | func testAccessFail(t *testing.T, expected verror.ID, ctx *context.T, who string, name ...string) { |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 37 | if _, err := utiltest.StatsStub(name...).Value(ctx); verror.ErrorID(err) != expected { |
Robert Kroeger | 8f914be | 2015-03-14 16:32:37 -0700 | [diff] [blame] | 38 | t.Fatalf(testutil.FormatLogLine(2, "%s got error %v but expected %v", who, err, expected)) |
| 39 | } |
| 40 | } |
| 41 | |
| 42 | func TestDebugPermissionsPropagation(t *testing.T) { |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 43 | cleanup, ctx, sh, envelope, root, helperPath, idp := utiltest.StartupHelper(t) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 44 | defer cleanup() |
| 45 | |
| 46 | // Set up the device manager. |
Todd Wang | 5fc3644 | 2015-04-07 15:15:27 -0700 | [diff] [blame] | 47 | dmh := servicetest.RunCommand(t, sh, nil, deviceManagerCmd, "dm", root, helperPath, "unused_app_repo_name", "unused_curr_link") |
| 48 | servicetest.ReadPID(t, dmh) |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 49 | utiltest.ClaimDevice(t, ctx, "claimable", "dm", "mydevice", noPairingToken) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 50 | |
| 51 | // Create the local server that the app uses to let us know it's ready. |
Robert Kroeger | 658e091 | 2015-04-30 10:30:57 -0700 | [diff] [blame^] | 52 | pingCh, cleanup := utiltest.SetupPingServer(t, ctx) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 53 | defer cleanup() |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 54 | utiltest.Resolve(t, ctx, "pingserver", 1) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 55 | |
| 56 | // Make some users. |
| 57 | selfCtx := ctx |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 58 | bobCtx := utiltest.CtxWithNewPrincipal(t, selfCtx, idp, "bob") |
| 59 | hjCtx := utiltest.CtxWithNewPrincipal(t, selfCtx, idp, "hackerjoe") |
| 60 | aliceCtx := utiltest.CtxWithNewPrincipal(t, selfCtx, idp, "alice") |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 61 | |
Benjamin Prosnitz | b60efb9 | 2015-03-11 17:47:43 -0700 | [diff] [blame] | 62 | // TODO(rjkroege): Set AccessLists here that conflict with the one provided by the device |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 63 | // manager and show that the one set here is overridden. |
| 64 | // Create the envelope for the first version of the app. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 65 | *envelope = utiltest.EnvelopeFromShell(sh, nil, appCmd, "google naps", "appV1") |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 66 | |
| 67 | // Install the app. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 68 | appID := utiltest.InstallApp(t, ctx) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 69 | |
| 70 | // Give bob rights to start an app. |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 71 | updateAccessList(t, selfCtx, "root/bob/$", string(access.Read), "dm/apps", appID) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 72 | |
| 73 | // Bob starts an instance of the app. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 74 | bobApp := utiltest.LaunchApp(t, bobCtx, appID) |
Robert Kroeger | 658e091 | 2015-04-30 10:30:57 -0700 | [diff] [blame^] | 75 | pingCh.VerifyPingArgs(t, userName(t), "default", "") |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 76 | |
| 77 | // Bob permits Alice to read from his app. |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 78 | updateAccessList(t, bobCtx, "root/alice/$", string(access.Read), "dm/apps", appID, bobApp) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 79 | |
Robert Kroeger | 8f914be | 2015-03-14 16:32:37 -0700 | [diff] [blame] | 80 | // Create some globbing test vectors. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 81 | globtests := []utiltest.GlobTestVector{ |
Robert Kroeger | 8f914be | 2015-03-14 16:32:37 -0700 | [diff] [blame] | 82 | {naming.Join("dm", "apps", appID, bobApp), "*", |
| 83 | []string{"logs", "pprof", "stats"}, |
| 84 | }, |
| 85 | {naming.Join("dm", "apps", appID, bobApp, "stats", "system"), |
| 86 | "start-time*", |
| 87 | []string{"start-time-rfc1123", "start-time-unix"}, |
| 88 | }, |
| 89 | {naming.Join("dm", "apps", appID, bobApp, "logs"), |
| 90 | "*", |
| 91 | []string{ |
| 92 | "STDERR-<timestamp>", |
| 93 | "STDOUT-<timestamp>", |
| 94 | "app.INFO", |
| 95 | "app.<*>.INFO.<timestamp>", |
| 96 | }, |
| 97 | }, |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 98 | } |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 99 | appGlobtests := []utiltest.GlobTestVector{ |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 100 | {naming.Join("appV1", "__debug"), "*", |
| 101 | []string{"logs", "pprof", "stats", "vtrace"}, |
| 102 | }, |
| 103 | {naming.Join("appV1", "__debug", "stats", "system"), |
| 104 | "start-time*", |
| 105 | []string{"start-time-rfc1123", "start-time-unix"}, |
| 106 | }, |
| 107 | {naming.Join("appV1", "__debug", "logs"), |
| 108 | "*", |
| 109 | []string{ |
| 110 | "STDERR-<timestamp>", |
| 111 | "STDOUT-<timestamp>", |
| 112 | "app.INFO", |
| 113 | "app.<*>.INFO.<timestamp>", |
| 114 | }, |
| 115 | }, |
| 116 | } |
Robert Kroeger | 8f914be | 2015-03-14 16:32:37 -0700 | [diff] [blame] | 117 | globtestminus := globtests[1:] |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 118 | res := utiltest.NewGlobTestRegexHelper("app") |
Robert Kroeger | 8f914be | 2015-03-14 16:32:37 -0700 | [diff] [blame] | 119 | |
| 120 | // Confirm that self can access __debug names. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 121 | utiltest.VerifyGlob(t, selfCtx, "app", globtests, res) |
| 122 | utiltest.VerifyStatsValues(t, selfCtx, "dm", "apps", appID, bobApp, "stats/system/start-time*") |
| 123 | utiltest.VerifyLog(t, selfCtx, "dm", "apps", appID, bobApp, "logs", "*") |
| 124 | utiltest.VerifyPProfCmdLine(t, selfCtx, "app", "dm", "apps", appID, bobApp, "pprof") |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 125 | |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 126 | // Bob started the app so selfCtx can't connect to the app. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 127 | utiltest.VerifyFailGlob(t, selfCtx, appGlobtests) |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 128 | testAccessFail(t, verror.ErrNoAccess.ID, selfCtx, "self", "appV1", "__debug", "stats/system/pid") |
| 129 | |
| 130 | // hackerjoe (for example) can't either. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 131 | utiltest.VerifyFailGlob(t, hjCtx, appGlobtests) |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 132 | testAccessFail(t, verror.ErrNoAccess.ID, hjCtx, "hackerjoe", "appV1", "__debug", "stats/system/pid") |
| 133 | |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 134 | // Bob has an issue with his app and tries to use the debug output to figure it out. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 135 | utiltest.VerifyGlob(t, bobCtx, "app", globtests, res) |
| 136 | utiltest.VerifyStatsValues(t, bobCtx, "dm", "apps", appID, bobApp, "stats/system/start-time*") |
| 137 | utiltest.VerifyLog(t, bobCtx, "dm", "apps", appID, bobApp, "logs", "*") |
| 138 | utiltest.VerifyPProfCmdLine(t, bobCtx, "app", "dm", "apps", appID, bobApp, "pprof") |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 139 | |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 140 | // Bob can also connect directly to his app. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 141 | utiltest.VerifyGlob(t, bobCtx, "app", appGlobtests, res) |
| 142 | utiltest.VerifyStatsValues(t, bobCtx, "appV1", "__debug", "stats/system/start-time*") |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 143 | |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 144 | // But Bob can't figure it out and hopes that hackerjoe can debug it. |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 145 | updateAccessList(t, bobCtx, "root/hackerjoe/$", string(access.Debug), "dm/apps", appID, bobApp) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 146 | |
Robert Kroeger | 16ee22b | 2015-03-12 14:57:09 -0700 | [diff] [blame] | 147 | // Fortunately the device manager permits hackerjoe to access the stats. |
| 148 | // But hackerjoe can't solve Bob's problem. |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 149 | // Because hackerjoe has Debug, hackerjoe can glob the __debug resources |
Robert Kroeger | 8f914be | 2015-03-14 16:32:37 -0700 | [diff] [blame] | 150 | // of Bob's app but can't glob Bob's app. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 151 | utiltest.VerifyGlob(t, hjCtx, "app", globtestminus, res) |
| 152 | utiltest.VerifyFailGlob(t, hjCtx, globtests[0:1]) |
| 153 | utiltest.VerifyStatsValues(t, hjCtx, "dm", "apps", appID, bobApp, "stats", "system/start-time*") |
| 154 | utiltest.VerifyLog(t, hjCtx, "dm", "apps", appID, bobApp, "logs", "*") |
| 155 | utiltest.VerifyPProfCmdLine(t, hjCtx, "app", "dm", "apps", appID, bobApp, "pprof") |
Robert Kroeger | 16ee22b | 2015-03-12 14:57:09 -0700 | [diff] [blame] | 156 | |
Robert Kroeger | 9732f01 | 2015-03-16 13:41:25 -0700 | [diff] [blame] | 157 | // Permissions are propagated to the app so hackerjoe can connect |
| 158 | // directly to the app too. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 159 | utiltest.VerifyGlob(t, hjCtx, "app", globtestminus, res) |
| 160 | utiltest.VerifyStatsValues(t, hjCtx, "appV1", "__debug", "stats/system/start-time*") |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 161 | |
Adam Sadovsky | a4d4a69 | 2015-04-20 11:36:49 -0700 | [diff] [blame] | 162 | // Alice might be able to help but Bob didn't give Alice access to the debug Permissionss. |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 163 | testAccessFail(t, verror.ErrNoAccess.ID, aliceCtx, "Alice", "dm", "apps", appID, bobApp, "stats/system/pid") |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 164 | |
Robert Kroeger | 16ee22b | 2015-03-12 14:57:09 -0700 | [diff] [blame] | 165 | // Bob forgets that Alice can't read the stats when he can. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 166 | utiltest.VerifyGlob(t, bobCtx, "app", globtests, res) |
| 167 | utiltest.VerifyStatsValues(t, bobCtx, "dm", "apps", appID, bobApp, "stats/system/start-time*") |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 168 | |
Robert Kroeger | 16ee22b | 2015-03-12 14:57:09 -0700 | [diff] [blame] | 169 | // So Bob changes the permissions so that Alice can help debug too. |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 170 | updateAccessList(t, bobCtx, "root/alice/$", string(access.Debug), "dm/apps", appID, bobApp) |
Robert Kroeger | 16ee22b | 2015-03-12 14:57:09 -0700 | [diff] [blame] | 171 | |
| 172 | // Alice can access __debug content. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 173 | utiltest.VerifyGlob(t, aliceCtx, "app", globtestminus, res) |
| 174 | utiltest.VerifyFailGlob(t, aliceCtx, globtests[0:1]) |
| 175 | utiltest.VerifyStatsValues(t, aliceCtx, "dm", "apps", appID, bobApp, "stats", "system/start-time*") |
| 176 | utiltest.VerifyLog(t, aliceCtx, "dm", "apps", appID, bobApp, "logs", "*") |
| 177 | utiltest.VerifyPProfCmdLine(t, aliceCtx, "app", "dm", "apps", appID, bobApp, "pprof") |
Robert Kroeger | 16ee22b | 2015-03-12 14:57:09 -0700 | [diff] [blame] | 178 | |
Robert Kroeger | 9732f01 | 2015-03-16 13:41:25 -0700 | [diff] [blame] | 179 | // Alice can also now connect directly to the app. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 180 | utiltest.VerifyGlob(t, aliceCtx, "app", globtestminus, res) |
| 181 | utiltest.VerifyStatsValues(t, aliceCtx, "appV1", "__debug", "stats/system/start-time*") |
Robert Kroeger | bc22606 | 2015-03-16 17:24:07 -0700 | [diff] [blame] | 182 | |
Bogdan Caprita | 2b05032 | 2015-04-17 09:04:03 -0700 | [diff] [blame] | 183 | // Bob is glum because no one can help him fix his app so he terminates |
| 184 | // it. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 185 | utiltest.TerminateApp(t, bobCtx, appID, bobApp) |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 186 | |
| 187 | // Cleanly shut down the device manager. |
| 188 | syscall.Kill(dmh.Pid(), syscall.SIGINT) |
Robert Kroeger | 5358ddf | 2015-03-11 10:15:43 -0700 | [diff] [blame] | 189 | dmh.Expect("dm terminated") |
| 190 | dmh.ExpectEOF() |
Robert Kroeger | 6e4ed12 | 2015-03-06 13:03:54 -0800 | [diff] [blame] | 191 | } |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 192 | |
| 193 | func TestClaimSetsDebugPermissions(t *testing.T) { |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 194 | cleanup, ctx, sh, _, root, helperPath, idp := utiltest.StartupHelper(t) |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 195 | defer cleanup() |
| 196 | |
| 197 | extraLogDir, err := ioutil.TempDir(root, "testlogs") |
| 198 | if err != nil { |
| 199 | t.Fatalf("ioutil.TempDir failed: %v", err) |
| 200 | } |
| 201 | |
| 202 | // Set up the device manager. |
Todd Wang | 5fc3644 | 2015-04-07 15:15:27 -0700 | [diff] [blame] | 203 | dmh := servicetest.RunCommand(t, sh, nil, deviceManagerCmd, "--log_dir="+extraLogDir, "dm", root, helperPath, "unused", "unused_curr_link") |
| 204 | servicetest.ReadPID(t, dmh) |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 205 | |
| 206 | // Make some users. |
| 207 | selfCtx := ctx |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 208 | bobCtx := utiltest.CtxWithNewPrincipal(t, selfCtx, idp, "bob") |
| 209 | aliceCtx := utiltest.CtxWithNewPrincipal(t, selfCtx, idp, "alice") |
| 210 | hjCtx := utiltest.CtxWithNewPrincipal(t, selfCtx, idp, "hackerjoe") |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 211 | |
| 212 | // Bob claims the device manager. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 213 | utiltest.ClaimDevice(t, bobCtx, "claimable", "dm", "mydevice", noPairingToken) |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 214 | |
| 215 | // Create some globbing test vectors. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 216 | dmGlobtests := []utiltest.GlobTestVector{ |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 217 | {naming.Join("dm", "__debug"), "*", |
| 218 | []string{"logs", "pprof", "stats", "vtrace"}, |
| 219 | }, |
| 220 | {naming.Join("dm", "__debug", "stats", "system"), |
| 221 | "start-time*", |
| 222 | []string{"start-time-rfc1123", "start-time-unix"}, |
| 223 | }, |
| 224 | {naming.Join("dm", "__debug", "logs"), |
| 225 | "*", |
| 226 | []string{ |
| 227 | // STDERR and STDOUT are not handled through the log package so |
| 228 | // are not included here. |
| 229 | "impl.test.INFO", |
| 230 | "impl.test.<*>.INFO.<timestamp>", |
| 231 | }, |
| 232 | }, |
| 233 | } |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 234 | res := utiltest.NewGlobTestRegexHelper(`impl\.test`) |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 235 | |
| 236 | // Bob claimed the DM so can access it. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 237 | utiltest.VerifyGlob(t, bobCtx, "impl.test", dmGlobtests, res) |
| 238 | utiltest.VerifyStatsValues(t, bobCtx, "dm", "__debug", "stats/system/start-time*") |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 239 | |
| 240 | // Without permissions, hackerjoe can't access the device manager. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 241 | utiltest.VerifyFailGlob(t, hjCtx, dmGlobtests) |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 242 | testAccessFail(t, verror.ErrNoAccess.ID, hjCtx, "hackerjoe", "dm", "__debug", "stats/system/pid") |
| 243 | |
| 244 | // Bob gives system administrator Alice admin access to the dm and hence Alice |
| 245 | // can access the __debug space. |
| 246 | updateAccessList(t, bobCtx, "root/alice/$", string(access.Admin), "dm", "device") |
| 247 | |
Robert Kroeger | 3bbf3c7 | 2015-03-25 13:04:55 -0700 | [diff] [blame] | 248 | // Alice is an adminstrator and so can can access device manager __debug |
| 249 | // values. |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 250 | utiltest.VerifyGlob(t, aliceCtx, "impl.test", dmGlobtests, res) |
| 251 | utiltest.VerifyStatsValues(t, aliceCtx, "dm", "__debug", "stats/system/start-time*") |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 252 | |
| 253 | // Bob gives debug access to the device manager to hackerjoe |
| 254 | updateAccessList(t, bobCtx, "root/hackerjoe/$", string(access.Debug), "dm", "device") |
| 255 | |
Robert Kroeger | 3bbf3c7 | 2015-03-25 13:04:55 -0700 | [diff] [blame] | 256 | // hackerjoe can now access the device manager |
Robert Kroeger | 22fcb03 | 2015-04-30 07:40:11 -0700 | [diff] [blame] | 257 | utiltest.VerifyGlob(t, hjCtx, "impl.test", dmGlobtests, res) |
| 258 | utiltest.VerifyStatsValues(t, hjCtx, "dm", "__debug", "stats/system/start-time*") |
Robert Kroeger | 066ac71 | 2015-03-20 16:28:48 -0700 | [diff] [blame] | 259 | |
| 260 | // Cleanly shut down the device manager. |
| 261 | syscall.Kill(dmh.Pid(), syscall.SIGINT) |
| 262 | dmh.Expect("dm terminated") |
| 263 | dmh.ExpectEOF() |
| 264 | } |