Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Remove this.skip usage as a faster workaround to afterEach skipping #940

Merged
1 commit merged into from
Jul 7, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 4 additions & 12 deletions tests/integration/models/application.spec.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -921,13 +921,11 @@ describe 'Application Model', ->
before ->
balena.auth.logout()

describe 'arbitrary pinejs queries', ->
$it = if publicApp then it else it.skip

it 'should be able to retrieve the available public apps', ->
if !publicApp
this.skip()
return
describe 'arbitrary pinejs queries', ->

$it 'should be able to retrieve the available public apps', ->
balena.pine.get
resource: 'application'
options:
Expand All @@ -946,18 +944,12 @@ describe 'Application Model', ->


describe 'balena.models.application.get()', ->

[
'id'
'app_name'
'slug'
].forEach (prop) ->

it "should be able to get a public application by #{prop}", ->
if !publicApp
this.skip()
return

$it "should be able to get a public application by #{prop}", ->
balena.models.application.get(publicApp[prop])
.then (app) ->
m.chai.expect(app).to.have.property('id').that.is.a('number')
Expand Down
11 changes: 4 additions & 7 deletions tests/integration/models/billing.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -148,13 +148,10 @@ describe('Billing Model', function () {
const givenABillingAccountIt = (
description: string,
testFn: (...args: any[]) => any,
) =>
it(description, function () {
if (!hasActiveBillingAccount) {
return this.skip();
}
return testFn.apply(this, arguments);
});
) => {
const $it = hasActiveBillingAccount ? it : it.skip;
$it(description, testFn);
};

before(() =>
loginPaidUser()
Expand Down
65 changes: 27 additions & 38 deletions tests/integration/models/tags.ts
Original file line number Diff line number Diff line change
Expand Up @@ -136,30 +136,25 @@ exports.itShouldSetGetAndRemoveTags = function (opts: Options) {

['id', ...uniquePropertyNames].forEach((param) =>
describe(`given a ${resourceName} ${param}`, function () {
it(`should be rejected if the ${resourceName} id does not exist`, function () {
if (!param) {
return this.skip();
}
const resourceUniqueKey = param === 'id' ? 999999 : '123456789';
const promise = model.set(resourceUniqueKey, 'EDITOR', 'vim');
return expect(promise).to.be.rejectedWith(
`${_.startCase(resourceName)} not found: ${resourceUniqueKey}`,
);
});
const $it = param ? it : it.skip;
$it(
`should be rejected if the ${resourceName} id does not exist`,
function () {
const resourceUniqueKey = param === 'id' ? 999999 : '123456789';
const promise = model.set(resourceUniqueKey, 'EDITOR', 'vim');
return expect(promise).to.be.rejectedWith(
`${_.startCase(resourceName)} not found: ${resourceUniqueKey}`,
);
},
);

it('should initially have no tags', function () {
if (!param) {
return this.skip();
}
$it('should initially have no tags', function () {
return getAllByResource(this.resource[param]).then((tags) =>
expect(tags).to.have.length(0),
);
});

it('...should be able to create a tag', function () {
if (!param) {
return this.skip();
}
$it('...should be able to create a tag', function () {
const promise = model.set(
this.resource[param],
`EDITOR_BY_${resourceName}_${param}`,
Expand All @@ -168,23 +163,20 @@ exports.itShouldSetGetAndRemoveTags = function (opts: Options) {
return expect(promise).to.not.be.rejected;
});

it('...should be able to retrieve all tags, including the one created', function () {
if (!param) {
return this.skip();
}
return getAllByResource(this.resource[param]).then(function (tags) {
expect(tags).to.have.length(1);
const tag = tags[0];
expect(tag).to.be.an('object');
expect(tag.tag_key).to.equal(`EDITOR_BY_${resourceName}_${param}`);
expect(tag.value).to.equal('vim');
});
});
$it(
'...should be able to retrieve all tags, including the one created',
function () {
return getAllByResource(this.resource[param]).then(function (tags) {
expect(tags).to.have.length(1);
const tag = tags[0];
expect(tag).to.be.an('object');
expect(tag.tag_key).to.equal(`EDITOR_BY_${resourceName}_${param}`);
expect(tag.value).to.equal('vim');
});
},
);

it('...should be able to update a tag', function () {
if (!param) {
return this.skip();
}
$it('...should be able to update a tag', function () {
return model
.set(
this.resource[param],
Expand All @@ -203,10 +195,7 @@ exports.itShouldSetGetAndRemoveTags = function (opts: Options) {
});
});

it('...should be able to remove a tag', function () {
if (!param) {
return this.skip();
}
$it('...should be able to remove a tag', function () {
return model
.remove(this.resource[param], `EDITOR_BY_${resourceName}_${param}`)
.then(() => {
Expand Down
24 changes: 7 additions & 17 deletions tests/integration/setup.coffee
Original file line number Diff line number Diff line change
Expand Up @@ -146,16 +146,11 @@ exports.givenAnApplication = (beforeFn) ->
exports.givenInitialOrganization(beforeFn)

beforeFn ->
# calling this.skip() doesn't trigger afterEach,
# so we need to reset in here as well
# See: https://github.com/mochajs/mocha/issues/3740
resetApplications()
.then =>
balena.models.application.create
name: 'FooBar'
applicationType: 'microservices-starter'
deviceType: 'raspberry-pi'
organization: @initialOrg.id
balena.models.application.create
name: 'FooBar'
applicationType: 'microservices-starter'
deviceType: 'raspberry-pi'
organization: @initialOrg.id
.then (@application) =>
chai.expect(@application.is_for__device_type).to.be.an('object')
.that.has.property('__id').that.is.a('number')
Expand All @@ -180,13 +175,8 @@ resetDevices = ->

exports.givenADevice = (beforeFn, extraDeviceProps) ->
beforeFn ->
# calling this.skip() doesn't trigger afterEach,
# so we need to reset in here as well
# See: https://github.com/mochajs/mocha/issues/3740
resetDevices()
.then =>
uuid = balena.models.device.generateUniqueKey()
balena.models.device.register(@application.app_name, uuid)
uuid = balena.models.device.generateUniqueKey()
balena.models.device.register(@application.app_name, uuid)
.tap (deviceInfo) =>
if !@currentRelease || [email protected]
return
Expand Down
13 changes: 3 additions & 10 deletions tests/util_ts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ export const describeExpandAssertions = async <T>(
describe(`expanding from ${params.resource}`, function () {
Object.keys(params.options.$expand).forEach((key) => {
describe(`to ${key}`, function () {
it('should succeed', async function () {
it('should succeed and include the expanded property', async function () {
const [result] = await balena.pine.get<AnyObject>({
...params,
options: {
Expand All @@ -19,16 +19,9 @@ export const describeExpandAssertions = async <T>(
},
},
});
this.result = result;
});

it('should include the expanded property', function () {
if (!this.result) {
this.skip();
return;
if (result) {
expect(result).to.have.property(key).that.is.an('array');
}

expect(this.result).to.have.property(key).that.is.an('array');
});
});
});
Expand Down