@skilltree/skills-client-js
Version:
SkillTree Client Lib - Native JS Lib
105 lines (89 loc) • 3.79 kB
JavaScript
/*
* Copyright 2025 SkillTree
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import mock from 'xhr-mock';
import SkillsConfiguration from '../../src/config/SkillsConfiguration';
import { SkillsReporter } from '../../src/reporter/SkillsReporter';
require('@babel/polyfill');
describe('authFormTests()', () => {
const mockServiceUrl = 'http://some.com';
const mockProjectId = 'proj1';
const authEndpoint = `${mockServiceUrl}/auth/endpoint`;
// replace the real XHR object with the mock XHR object before each test
beforeEach(() => {
mock.setup();
SkillsConfiguration.logout();
const url = /.*\/api\/projects\/proj1\/skillsClientVersion/;
mock.post(url, (req, res) => res.status(200).body('{"success":true,"explanation":null}'));
mock.get(/.*\/public\/status/, (req, res) => res.status(200).body('{"status":"OK","clientLib":{"loggingEnabled":"false","loggingLevel":"DEBUG"}}'));
});
// put the real XHR object back and clear the mocks after each test
afterEach(() => {
SkillsConfiguration.logout();
mock.teardown();
});
it('successful call', async () => {
expect.assertions(2);
const mockUserSkillId = 'skill1';
mock.get(authEndpoint, (req, res) => res.status(200).body('{"access_token": "token"}'));
SkillsConfiguration.configure({
serviceUrl: mockServiceUrl,
projectId: mockProjectId,
authenticator: authEndpoint,
});
const url = `${mockServiceUrl}/api/projects/${mockProjectId}/skills/${mockUserSkillId}`;
mock.post(url, (req, res) => {
expect(req.header('Authorization')).toEqual('Bearer token');
return res.status(200).body('{"data":{"id":"abc-123"}}');
});
const res = await SkillsReporter.reportSkill('skill1');
expect(res).toEqual({ data: { id: 'abc-123' } });
});
it('unable to auth because of non 200 status code', async () => {
expect.assertions(1);
mock.get(authEndpoint, (req, res) => res.status(401).body('{"access_token": "token"}'));
SkillsConfiguration.configure({
serviceUrl: mockServiceUrl,
projectId: mockProjectId,
authenticator: authEndpoint,
});
await new Promise(process.nextTick);
const mockUserSkillId = 'skill1';
const url = `${mockServiceUrl}/api/projects/${mockProjectId}/skills/${mockUserSkillId}`;
mock.post(url, (req, res) => res.status(200).body('{"data":{"id":"abc-123"}}'));
try {
await SkillsReporter.reportSkill('skill1');
} catch (e) {
expect(e.message).toMatch('Unable to authenticate');
}
});
it('unable to auth because access_token is missing', async () => {
expect.assertions(1);
mock.get(authEndpoint, (req, res) => res.status(200).body('{"not_access_token": "token"}'));
SkillsConfiguration.configure({
serviceUrl: mockServiceUrl,
projectId: mockProjectId,
authenticator: authEndpoint,
});
const mockUserSkillId = 'skill1';
const url = `${mockServiceUrl}/api/projects/${mockProjectId}/skills/${mockUserSkillId}`;
mock.post(url, (req, res) => res.status(200).body('{"data":{"id":"abc-123"}}'));
try {
await SkillsReporter.reportSkill('skill1');
} catch (e) {
expect(e.message).toMatch('Full Response=[{\"not_access_token\": \"token\"}]');
}
});
});