mirror of
https://github.com/serverless/serverless.git
synced 2026-01-25 15:07:39 +00:00
62 lines
1.6 KiB
JavaScript
62 lines
1.6 KiB
JavaScript
'use strict';
|
|
|
|
const expect = require('chai').expect;
|
|
const sinon = require('sinon');
|
|
const Logs = require('./logs');
|
|
const Serverless = require('../../Serverless');
|
|
|
|
describe('Logs', () => {
|
|
let logs;
|
|
let serverless;
|
|
|
|
beforeEach(() => {
|
|
serverless = new Serverless();
|
|
logs = new Logs(serverless);
|
|
});
|
|
|
|
describe('#constructor()', () => {
|
|
it('should have commands', () => expect(logs.commands).to.be.not.empty);
|
|
});
|
|
|
|
describe('#track()', () => {
|
|
let userStats;
|
|
|
|
beforeEach(() => {
|
|
userStats = { track: sinon.spy() };
|
|
});
|
|
|
|
describe('Without cli processed input', () => {
|
|
it('do not track user stats', () => {
|
|
const newLogs = new Logs(serverless, userStats);
|
|
|
|
return newLogs.track()
|
|
.then(() => {
|
|
expect(userStats.track.called).to.be.equal(false);
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('With cli processed input', () => {
|
|
it('tracks user stats with viewed option', () => {
|
|
serverless.processedInput = { commands: [], options: {} };
|
|
|
|
return new Logs(serverless, userStats).track()
|
|
.then(() => {
|
|
expect(userStats.track.calledWithExactly('service_logsViewed'))
|
|
.to.be.equal(true);
|
|
});
|
|
});
|
|
|
|
it('tracks user stats with tailed option', () => {
|
|
serverless.processedInput = { commands: [], options: { tail: true } };
|
|
|
|
return new Logs(serverless, userStats).track()
|
|
.then(() => {
|
|
expect(userStats.track.calledWithExactly('service_logsTailed'))
|
|
.to.be.equal(true);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
});
|