Skip to content
Merged
Show file tree
Hide file tree
Changes from 1 commit
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
Prev Previous commit
feat: supress error (#26)
fix: eslint (#31)
  • Loading branch information
technote-space committed Sep 15, 2019
commit 460797e9d4493a810a64ae929e85a4fd6583b47c
4 changes: 4 additions & 0 deletions __tests__/fixtures/repos.issues.assignees.403.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
{
"message": "Resource not accessible by integration",
"documentation_url": "https://developer.github.com/v3"
}
73 changes: 37 additions & 36 deletions __tests__/util.ts
Original file line number Diff line number Diff line change
@@ -1,36 +1,37 @@
const fs = require('fs');
const path = require('path');

export const getContext = (override: object) => Object.assign({
payload: {
action: '',
},
eventName: '',
sha: '',
ref: '',
workflow: '',
action: '',
actor: '',
issue: {
owner: '',
repo: '',
number: 1,
},
repo: {
owner: '',
repo: '',
},
}, override);

export const getApiFixture = (name: string) => JSON.parse(fs.readFileSync(path.resolve(__dirname, `./fixtures/${name}.json`)));

export const disableNetConnect = nock => {
beforeEach(() => {
nock.disableNetConnect();
});

afterEach(() => {
nock.cleanAll();
nock.enableNetConnect();
});
};
import { Context } from '@actions/github/lib/context';
import * as fs from 'fs';
import * as path from 'path';

export const getContext = (override: object): Context => Object.assign({
payload: {
action: '',
},
eventName: '',
sha: '',
ref: '',
workflow: '',
action: '',
actor: '',
issue: {
owner: '',
repo: '',
number: 1,
},
repo: {
owner: '',
repo: '',
},
}, override);

export const getApiFixture = (name: string): object => JSON.parse(fs.readFileSync(path.resolve(__dirname, `./fixtures/${name}.json`)).toString());

export const disableNetConnect = (nock): void => {
beforeEach(() => {
nock.disableNetConnect();
});

afterEach(() => {
nock.cleanAll();
nock.enableNetConnect();
});
};
245 changes: 123 additions & 122 deletions __tests__/utils/context.test.ts
Original file line number Diff line number Diff line change
@@ -1,122 +1,123 @@
import {getAssignees} from '../../src/utils/context';
import {getContext} from '../util';

describe('getAssignees', () => {
it('should get issue assignees', () => {
expect(getAssignees(getContext({
eventName: 'issues',
payload: {
sender: {
type: 'User',
login: 'test',
},
issue: {
assignees: [],
},
},
}))).toEqual(['test']);
});

it('should get PR assignees', () => {
expect(getAssignees(getContext({
eventName: 'pull_request',
payload: {
sender: {
type: 'User',
login: 'test',
},
pull_request: {
assignees: [],
},
},
}))).toEqual(['test']);
});

it('should empty 1', () => {
expect(getAssignees(getContext({
eventName: 'issues',
payload: {
sender: {
type: 'User',
login: 'test',
},
issue: {
assignees: [
{login: 'test'},
{login: 'test2'},
],
},
},
}))).toEqual([]);
});

it('should empty 2', () => {
expect(getAssignees(getContext({
eventName: 'pull_request',
payload: {
sender: {
type: 'User',
login: 'test',
},
pull_request: {
assignees: [
{login: 'test'},
{login: 'test2'},
],
},
},
}))).toEqual([]);
});

it('should return false 1', () => {
expect(getAssignees(getContext({
eventName: 'issues',
payload: {
issue: {
assignees: [],
},
},
}))).toBeFalsy();
});

it('should return false 2', () => {
expect(getAssignees(getContext({
eventName: 'issues',
payload: {
sender: {
type: 'User',
login: 'test',
},
issue: {},
},
}))).toBeFalsy();
});

it('should return false 3', () => {
expect(getAssignees(getContext({
eventName: 'pull_request',
payload: {
sender: {
type: 'User',
login: 'test',
},
pull_request: {},
},
}))).toBeFalsy();
});

it('should return false 4', () => {
expect(getAssignees(getContext({
eventName: 'push',
payload: {
sender: {
type: 'User',
login: 'test',
},
issue: {
assignees: [],
},
},
}))).toBeFalsy();
});
});
/* eslint-disable no-magic-numbers */
import { getAssignees } from '../../src/utils/context';
import { getContext } from '../util';

describe('getAssignees', () => {
it('should get issue assignees', () => {
expect(getAssignees(getContext({
eventName: 'issues',
payload: {
sender: {
type: 'User',
login: 'test',
},
issue: {
assignees: [],
},
},
}))).toEqual(['test']);
});

it('should get PR assignees', () => {
expect(getAssignees(getContext({
eventName: 'pull_request',
payload: {
sender: {
type: 'User',
login: 'test',
},
'pull_request': {
assignees: [],
},
},
}))).toEqual(['test']);
});

it('should empty 1', () => {
expect(getAssignees(getContext({
eventName: 'issues',
payload: {
sender: {
type: 'User',
login: 'test',
},
issue: {
assignees: [
{login: 'test'},
{login: 'test2'},
],
},
},
}))).toEqual([]);
});

it('should empty 2', () => {
expect(getAssignees(getContext({
eventName: 'pull_request',
payload: {
sender: {
type: 'User',
login: 'test',
},
'pull_request': {
assignees: [
{login: 'test'},
{login: 'test2'},
],
},
},
}))).toEqual([]);
});

it('should return false 1', () => {
expect(getAssignees(getContext({
eventName: 'issues',
payload: {
issue: {
assignees: [],
},
},
}))).toBeFalsy();
});

it('should return false 2', () => {
expect(getAssignees(getContext({
eventName: 'issues',
payload: {
sender: {
type: 'User',
login: 'test',
},
issue: {},
},
}))).toBeFalsy();
});

it('should return false 3', () => {
expect(getAssignees(getContext({
eventName: 'pull_request',
payload: {
sender: {
type: 'User',
login: 'test',
},
'pull_request': {},
},
}))).toBeFalsy();
});

it('should return false 4', () => {
expect(getAssignees(getContext({
eventName: 'push',
payload: {
sender: {
type: 'User',
login: 'test',
},
issue: {
assignees: [],
},
},
}))).toBeFalsy();
});
});
Loading