balena-supervisor/test/unit/lib/journald.spec.ts
Felipe Lalanne 91b119cbae Stop using host journalctl
The supervisor had to chroot into the host root in order to read the
journal logs. This won't be possible anymore once the supervisor becomes
an app. This commit copies the journalctl binary and necessary libraries
from a debian image into the supervisor image in order to be able to use
the tool on runtime.

Change-type: patch
2022-12-05 17:09:20 -03:00

57 lines
1.2 KiB
TypeScript

import { SinonStub, stub } from 'sinon';
import { expect } from 'chai';
import { spawnJournalctl } from '~/lib/journald';
describe('lib/journald', () => {
let spawn: SinonStub;
beforeEach((done) => {
spawn = stub(require('child_process'), 'spawn');
done();
});
afterEach((done) => {
spawn.restore();
done();
});
// TODO: this test is not really that useful as it basically is just testing
// the internal implementation of the method
it('spawnJournalctl calls spawn child process with expected args', () => {
spawnJournalctl({
all: true,
follow: true,
count: 10,
unit: 'nginx.service',
containerId: 'abc123',
format: 'json-pretty',
});
const expectedCommand = `journalctl`;
const expectedOptionalArgs = [
'-a',
'--follow',
'-u',
'nginx.service',
'-t',
'abc123',
'-n',
'10',
'-o',
'json-pretty',
];
const actualCommand = spawn.firstCall.args[0];
const actualOptionalArgs = spawn.firstCall.args[1];
expect(spawn.calledOnce).to.be.true;
expect(actualCommand).deep.equal(expectedCommand);
expectedOptionalArgs.forEach((arg) => {
expect(actualOptionalArgs).to.include(arg);
});
});
});