Skip to content
Open
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
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import {trainerApi} from '../../../../../rest-api';

export const fetchTrainingContentStarted = (trainingId: number) => {
return (dispatcher) => {
const promise = trainerApi.getTrainingConentByTrainingId(trainingId);
const promise = trainerApi.getTrainingContentByTrainingId(trainingId);

promise.then(
(data) => dispatcher(fetchTrainingContentCompleted(data)),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -52,15 +52,15 @@ describe('fetchTrainingContentStarted', () => {
});
});

it('should calls to getTrainingConentByTrainingId and expect payload', sinon.test((done) => {
it('should calls to getTrainingContentByTrainingId and expect payload', sinon.test((done) => {
// Arrange
const sinon: sinon.SinonStatic = this;

const trainingId = 1;
const expectedContent = 'Test content';
const store = mockStore([]);

const getTrainingConentByTrainingIdStub = sinon.stub(trainerApi, 'getTrainingConentByTrainingId', () => {
const getTrainingContentByTrainingIdStub = sinon.stub(trainerApi, 'getTrainingContentByTrainingId', () => {
return {
then: (callback) => {
callback(expectedContent);
Expand All @@ -72,7 +72,7 @@ describe('fetchTrainingContentStarted', () => {
store.dispatch(fetchTrainingContentStarted(trainingId))
.then(() => {
// Assert
expect(getTrainingConentByTrainingIdStub.calledWith(trainingId)).to.be.true;
expect(getTrainingContentByTrainingIdStub.calledWith(trainingId)).to.be.true;
expect(store.getActions()[0].payload).to.equal(expectedContent);

done();
Expand Down
34 changes: 31 additions & 3 deletions src/rest-api/trainer/spec/trainerApi.spec.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
import {expect} from 'chai';
import * as trainerMockData from '../trainerMockData';
import * as exerciseEvaluationMockData from '../exerciseEvaluationMockedData';
import {EditTrainingSummary} from '../../../model/trainer/editTrainingSummary';
import { ExerciseEvaluation } from '../../../model/trainer/deliveryEvaluation';
import {trainerApi} from '../trainerApi';

describe('TrainerApi', () => {
Expand All @@ -9,7 +11,7 @@ describe('TrainerApi', () => {
expect(trainerApi).not.to.be.undefined;
});

describe('getTrainingConentByTrainingId', () => {
describe('getTrainingContentByTrainingId', () => {
it('returns expected content by id equals 1', sinon.test((done) => {
// Arrange
const sinon: sinon.SinonStatic = this;
Expand All @@ -26,7 +28,7 @@ describe('TrainerApi', () => {
);

// Act
const promise = trainerApi.getTrainingConentByTrainingId(id);
const promise = trainerApi.getTrainingContentByTrainingId(id);

promise.then((content) => {
// Assert
Expand Down Expand Up @@ -54,7 +56,7 @@ describe('TrainerApi', () => {
);

// Act
const promise = trainerApi.getTrainingConentByTrainingId(id);
const promise = trainerApi.getTrainingContentByTrainingId(id);

promise.then((content) => {
// Assert
Expand All @@ -63,4 +65,30 @@ describe('TrainerApi', () => {
});
}).bind(this));
});

describe('getExerciseEvaluationById', () => {
it('returns expected Exercise Evaluation by id equals 1', sinon.test((done) => {
// Arrange
const sinon: sinon.SinonStatic = this;
const id = 123;
const expectedMockEvaluation: ExerciseEvaluation = {
id: 123,
name: 'Exercise delivery - Module UX + Design',
studentDelivery:null
};
const exerciseEvaluationMockDataStub = sinon.stub(exerciseEvaluationMockData, 'exerciseEvaluationMockedData',
[expectedMockEvaluation],
);

// Act
const promise = trainerApi.getExerciseEvaluationById(id);

promise.then((content) => {
// Assert
expect(content.name).to.equal(expectedMockEvaluation.name);
done();
});
}).bind(this));

});
});
21 changes: 20 additions & 1 deletion src/rest-api/trainer/trainerApi.ts
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
import {trainingContentMockData} from './trainerMockData';
import {exerciseEvaluationMockedData} from './exerciseEvaluationMockedData';
import { ExerciseEvaluation } from '../../model/trainer/deliveryEvaluation';

class TrainerApi {
public getTrainingConentByTrainingId(id: number): Promise<string> {
public getTrainingContentByTrainingId(id: number): Promise<string> {
let content: string;

const trainingContent = trainingContentMockData.filter((trainingMockData) => {
Expand All @@ -14,6 +16,23 @@ class TrainerApi {

return Promise.resolve(content);
}
public getExerciseEvaluationById(id: number): Promise<ExerciseEvaluation> {
let evaluation: ExerciseEvaluation;

const evaluationData = exerciseEvaluationMockedData.find((evaluationItem) => {
return evaluationItem.id === id;
});

if (evaluationData) {
evaluation = evaluationData;
}

return Promise.resolve(evaluationData);
}

public saveExerciseEvaluation(exerciseEvaluation:ExerciseEvaluation){
return Promise.resolve(exerciseEvaluation);
}
}

export const trainerApi = new TrainerApi();