Skip to content

Commit

Permalink
feat: expose ProcessPromise fullCmd and unique id
Browse files Browse the repository at this point in the history
relates google#1028
  • Loading branch information
antongolub committed Dec 25, 2024
1 parent 775b4b4 commit 56854e7
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 19 deletions.
43 changes: 25 additions & 18 deletions src/core.ts
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ import {
quote,
quotePowerShell,
toCamelCase,
randomId,
} from './util.js'

export { log, type LogEntry } from './util.js'
Expand Down Expand Up @@ -209,6 +210,7 @@ type PipeMethod = {
}

export class ProcessPromise extends Promise<ProcessOutput> {
private _id = randomId()
private _command = ''
private _from = ''
private _snapshot = getStore()
Expand Down Expand Up @@ -251,9 +253,8 @@ export class ProcessPromise extends Promise<ProcessOutput> {
this._run = true
this._pipedFrom?.run()

const $ = this._snapshot
const self = this
const input = ($.input as ProcessPromise | ProcessOutput)?.stdout ?? $.input
const $ = this._snapshot

if ($.timeout) this.timeout($.timeout, $.timeoutSignal)
if ($.preferLocal) {
Expand All @@ -268,22 +269,24 @@ export class ProcessPromise extends Promise<ProcessOutput> {
verbose: self.isVerbose(),
})

// prettier-ignore
this._zurk = exec({
input,
cmd: $.prefix + self._command + $.postfix,
cwd: $.cwd ?? $[CWD],
ac: $.ac,
signal: $.signal,
shell: isString($.shell) ? $.shell : true,
env: $.env,
spawn: $.spawn,
spawnSync: $.spawnSync,
store: $.store,
stdin: self._stdin,
stdio: self._stdio ?? $.stdio,
sync: $[SYNC],
id: self.id,
cmd: self.fullCmd,
cwd: $.cwd ?? $[CWD],
input: ($.input as ProcessPromise | ProcessOutput)?.stdout ?? $.input,
ac: $.ac,
signal: $.signal,
shell: isString($.shell) ? $.shell : true,
env: $.env,
spawn: $.spawn,
spawnSync:$.spawnSync,
store: $.store,
stdin: self._stdin,
stdio: self._stdio ?? $.stdio,
sync: $[SYNC],
detached: $.detached,
ee: self._ee,
ee: self._ee,
run: (cb) => cb(),
on: {
start: () => {
Expand All @@ -298,13 +301,11 @@ export class ProcessPromise extends Promise<ProcessOutput> {
// Stderr should be printed regardless of piping.
$.log({ kind: 'stderr', data, verbose: !self.isQuiet() })
},
// prettier-ignore
end: (data, c) => {
self._resolved = true
const { error, status, signal, duration, ctx } = data
const { stdout, stderr, stdall } = ctx.store
const dto: ProcessOutputLazyDto = {
// Lazy getters
code: () => status,
signal: () => signal,
duration: () => duration,
Expand Down Expand Up @@ -439,6 +440,8 @@ export class ProcessPromise extends Promise<ProcessOutput> {
}

// Getters
get id() { return this._id }

get pid(): number | undefined {
return this.child?.pid
}
Expand All @@ -447,6 +450,10 @@ export class ProcessPromise extends Promise<ProcessOutput> {
return this._command
}

get fullCmd(): string {
return this._snapshot.prefix + this.cmd + this._snapshot.postfix
}

get child(): ChildProcess | undefined {
return this._zurk?.child
}
Expand Down
4 changes: 3 additions & 1 deletion test/core.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -392,11 +392,13 @@ describe('core', () => {
const baz = 1
const p = $`echo ${foo} --t ${baz}`
assert.equal(p.cmd, "echo $'#bar' --t 1")
assert.equal(p.fullCmd, "set -euo pipefail;echo $'#bar' --t 1")
})

test('exposes pid', () => {
test('exposes pid & id', () => {
const p = $`echo foo`
assert.ok(p.pid > 0)
assert.ok(typeof p.id === 'string')
})

test('stdio() works', async () => {
Expand Down

0 comments on commit 56854e7

Please sign in to comment.