Some checks failed
build-packages / dedupe push run (push) Has been cancelled
build-packages / dedupe result (push) Has been cancelled
build-packages / resolve bundled mosh-client (push) Has been cancelled
build-packages / resolve bundled et-client (push) Has been cancelled
build-packages / build-macos (push) Has been cancelled
build-packages / build-windows (push) Has been cancelled
build-packages / ${{ needs.dedupe.outputs.skip_heavy_ci == 'true' && 'deduped build-linux-x64' || 'build-linux-x64' }} (push) Has been cancelled
build-packages / ${{ needs.dedupe.outputs.skip_heavy_ci == 'true' && 'deduped build-linux-arm64' || 'build-linux-arm64' }} (push) Has been cancelled
build-packages / release (push) Has been cancelled
build-packages / bump homebrew tap (push) Has been cancelled
* Enable sudo fallback for Docker panel * Prefer sudo for Docker panel commands * Use pending saved sudo password immediately * Try plain Docker before sudo fallback * Detect Docker before sudo fallback * Add sudo fallback for Docker popup commands * Harden Docker popup sudo fallback
31 lines
1.4 KiB
TypeScript
31 lines
1.4 KiB
TypeScript
import test from 'node:test';
|
|
import assert from 'node:assert/strict';
|
|
|
|
import { buildDockerExecShellCommand, buildDockerLogsCommand } from './dockerShell.ts';
|
|
|
|
test('buildDockerExecShellCommand probes plain Docker before sudo fallback', () => {
|
|
const command = buildDockerExecShellCommand('587abcdef123');
|
|
|
|
assert.match(command, /^sh -c /);
|
|
assert.match(command, /printf .*\\033\[H\\033\[2J\\033\[3J/);
|
|
assert.match(command, /docker inspect 587abcdef123/);
|
|
assert.match(command, /exec docker exec -it 587abcdef123/);
|
|
assert.match(command, /exec sudo docker exec -it 587abcdef123/);
|
|
assert.match(command, /permission\\ denied.*docker.sock.*docker.sock.*permission\\ denied/);
|
|
assert.doesNotMatch(command, /sudo -S/);
|
|
assert.equal(command.includes('\n'), false);
|
|
});
|
|
|
|
test('buildDockerLogsCommand probes plain Docker before sudo fallback', () => {
|
|
const command = buildDockerLogsCommand('587abcdef123');
|
|
|
|
assert.match(command, /^sh -c /);
|
|
assert.match(command, /printf .*\\033\[H\\033\[2J\\033\[3J/);
|
|
assert.match(command, /docker inspect 587abcdef123/);
|
|
assert.match(command, /exec docker logs -f --tail 200 587abcdef123/);
|
|
assert.match(command, /exec sudo docker logs -f --tail 200 587abcdef123/);
|
|
assert.match(command, /permission\\ denied.*docker.sock.*docker.sock.*permission\\ denied/);
|
|
assert.doesNotMatch(command, /sudo -S/);
|
|
assert.equal(command.includes('\n'), false);
|
|
});
|