diff options
author | ARULNA <arul.nambi@amdocs.com> | 2017-06-02 16:27:25 -0400 |
---|---|---|
committer | ARULNA <arul.nambi@amdocs.com> | 2017-06-02 16:33:14 -0400 |
commit | ca007e933bcd9f63aa77801656ed9dd4142c432c (patch) | |
tree | ce97ed9df8c4fe48a524f0dc1365ad28acef7c46 /test/components/dateRangeSelector.test.js | |
parent | 42b788b852f0604748828e9e325e4a0f01152c75 (diff) |
Initial coomit for AAI-UI(sparky-fe)
Change-Id: I9f8482824a52bac431c100939899e760c0fa4fdb
Signed-off-by: ARULNA <arul.nambi@amdocs.com>
Diffstat (limited to 'test/components/dateRangeSelector.test.js')
-rw-r--r-- | test/components/dateRangeSelector.test.js | 308 |
1 files changed, 308 insertions, 0 deletions
diff --git a/test/components/dateRangeSelector.test.js b/test/components/dateRangeSelector.test.js new file mode 100644 index 0000000..e78de48 --- /dev/null +++ b/test/components/dateRangeSelector.test.js @@ -0,0 +1,308 @@ +/* + * ============LICENSE_START======================================================= + * SPARKY (AAI UI service) + * ================================================================================ + * Copyright © 2017 AT&T Intellectual Property. + * Copyright © 2017 Amdocs + * All rights reserved. + * ================================================================================ + * 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 + * + * http://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. + * ============LICENSE_END========================================================= + * + * ECOMP and OpenECOMP are trademarks + * and service marks of AT&T Intellectual Property. + */ + +import React from "react"; +import TestUtils from "react-dom/lib/ReactTestUtils"; +import {Provider} from "react-redux"; +import {expect} from "chai"; +import {moment} from "moment"; +import store from "app/AppStore.js"; +import DateRangeSelector from "generic-components/dateRangeSelector/DateRangeSelector.jsx"; +import DateRangeSelectorActions from "generic-components/dateRangeSelector/DateRangeSelectorActions.js"; +import { + dateRangeSelectorActionTypes, + TODAY, + YESTERDAY, + LAST_WEEK, + LAST_MONTH, + CUSTOM, + ICON_CLASS_CALENDAR, + ICON_CLASS_DOWN_CARET, + ERROR_UNKNOWN_PERIOD} from "generic-components/dateRangeSelector/DateRangeSelectorConstants.js"; +import reducer from "generic-components/dateRangeSelector/DateRangeSelectorReducer.js"; +import {dateRangeActionTypes, DATE_PICKER_PLACEHOLDER} from "generic-components/dateRange/DateRangeConstants.js"; +import {MESSAGE_LEVEL_DANGER} from "utils/GlobalConstants.js"; + +describe("Date Range Selector Test Suite", function() { + + beforeEach(function () { + this.component = TestUtils.renderIntoDocument( <Provider store={store}><DateRangeSelector /></Provider>); + }); + + // test structure + it("Date Range Selector - Validate selector button", function () { + var moment = require('moment'); + let currentDate = moment(new Date()).format(DATE_PICKER_PLACEHOLDER); + let button = TestUtils.findRenderedDOMComponentWithTag(this.component, 'button'); + expect(button).exists; + expect(button.childNodes.length).to.equal(3); + expect(button.childNodes[0].className).to.have.string(ICON_CLASS_CALENDAR); + expect(button.childNodes[1].innerHTML).to.have.string(currentDate + ' - ' + currentDate); + expect(button.childNodes[2].className).to.have.string(ICON_CLASS_DOWN_CARET); + }); + + it("Date Range Selector - Validate quick pick options", function () { + let button = TestUtils.findRenderedDOMComponentWithTag(this.component, 'button'); + TestUtils.Simulate.click(button); + + let popoverMenu = document.body.getElementsByClassName('popover-content'); + // TODO - need to figure out how to get the popover menu (above doesn't work) + }); + + // test reducer + it("Date Range Selector Reducer ... Vaidate DATE_RANGE_CHANGE event)", function() { + var moment = require('moment'); + const initialState = { + startDate: moment(new Date('07/20/2016')), + endDate: moment(new Date('07/09/2016')), + period: CUSTOM, + periodErrText: 'some error text', + periodErrSev: 'some error severity' + }; + const rangeChangeAction = { + type: dateRangeActionTypes.DATE_RANGE_CHANGE, + data: { + dateRange: { + startDate: moment(new Date('05/04/2016')), + endDate: moment(new Date('06/05/2016')) + }, + errorMsg: '' + }}; + const newState = reducer(initialState, rangeChangeAction); + expect(newState.startDate).to.exist; + expect(newState.startDate.toDate().getTime()).to.equal(new Date('05/04/2016').getTime()); + expect(newState.endDate).to.exist; + expect(newState.endDate.toDate().getTime()).to.equal(new Date('06/05/2016').getTime()); + expect(newState.period).to.equal(CUSTOM); + expect(newState.periodErrText).to.equal(''); + expect(newState.periodErrSev).to.equal(''); + }); + it("Date Range Selector Reducer ... Vaidate INVALID_DATE_RANGE event)", function() { + var moment = require('moment'); + const initialState = {}; + const rangeChangeAction = { + type: dateRangeActionTypes.INVALID_DATE_RANGE, + data: { + dateRange: { + startDate: moment(new Date('07/04/2016')), + endDate: moment(new Date('06/05/2016')) + }, + errorMsg: 'some eror message' + }}; + const newState = reducer(initialState, rangeChangeAction); + expect(newState.startDate).to.exist; + expect(newState.startDate.toDate().getTime()).to.equal(new Date('07/04/2016').getTime()); + expect(newState.endDate).to.exist; + expect(newState.endDate.toDate().getTime()).to.equal(new Date('06/05/2016').getTime()); + expect(newState.period).to.not.exist; + expect(newState.periodErrText).to.equal('some eror message'); + expect(newState.periodErrSev).to.equal(MESSAGE_LEVEL_DANGER); + }); + it("Date Range Selector Reducer ... Vaidate PERIOD_CHANGE event)", function() { + var moment = require('moment'); + const initialState = { + startDate: moment(new Date('07/20/2016')), + endDate: moment(new Date('07/09/2016')), + period: CUSTOM, + periodErrText: 'some error text', + periodErrSev: 'some error severity' + }; + const rangeChangeAction = { + type: dateRangeSelectorActionTypes.EVENT_PERIOD_CHANGE, + data: { + dateRange: { + startDate: moment(new Date('07/04/2016')), + endDate: moment(new Date('07/05/2016')) + }, + period: YESTERDAY + } + }; + const newState = reducer(initialState, rangeChangeAction); + expect(newState.startDate).to.exist; + expect(newState.startDate.toDate().getTime()).to.equal(new Date('07/04/2016').getTime()); + expect(newState.endDate).to.exist; + expect(newState.endDate.toDate().getTime()).to.equal(new Date('07/05/2016').getTime()); + expect(newState.period).to.equal(YESTERDAY); + expect(newState.periodErrText).to.equal(''); + expect(newState.periodErrSev).to.equal(''); + }); + + // test Actions + it("Date Range Selector Action - test EVENT_PERIOD_CHANGE (period = Today)", function() { + var moment = require('moment'); + const startDate = moment(new Date()); + const endDate = moment(new Date()); + const period = TODAY; + + const results = DateRangeSelectorActions.onPeriodChange(startDate, endDate, period); + + const expectedStartTime = moment(new Date()); + setTime(expectedStartTime, 0, 0, 0); + const expectedEndTime = moment(new Date()); + setTime(expectedEndTime, 23, 59, 59); + const expectedAction = buildExpectedPeriodChangeAction(expectedStartTime, expectedEndTime, TODAY); + + expect(results.type).to.equal(expectedAction.type); + validateDates(results.data.dateRange.startDate, expectedAction.data.dateRange.startDate); + validateDates(results.data.dateRange.endDate, expectedAction.data.dateRange.endDate); + expect(results.data.period).to.equal(expectedAction.data.period); + }); + it("Date Range Selector Action - test EVENT_PERIOD_CHANGE (period = Yesterday)", function() { + var moment = require('moment'); + const startDate = moment(new Date()); + const endDate = moment(new Date()); + const period = YESTERDAY; + + const results = DateRangeSelectorActions.onPeriodChange(startDate, endDate, period); + + const expectedStartTime = moment(new Date()).subtract(1, 'days'); + setTime(expectedStartTime, 0, 0, 0); + const expectedEndTime = moment(new Date()); + setTime(expectedEndTime, 23, 59, 59); + const expectedAction = buildExpectedPeriodChangeAction(expectedStartTime, expectedEndTime, YESTERDAY); + + expect(results.type).to.equal(expectedAction.type); + validateDates(results.data.dateRange.startDate, expectedAction.data.dateRange.startDate); + validateDates(results.data.dateRange.endDate, expectedAction.data.dateRange.endDate); + expect(results.data.period).to.equal(expectedAction.data.period); + }); + it("Date Range Selector Action - test EVENT_PERIOD_CHANGE (period = Last Week)", function() { + var moment = require('moment'); + const startDate = moment(new Date()); + const endDate = moment(new Date()); + const period = LAST_WEEK; + + const results = DateRangeSelectorActions.onPeriodChange(startDate, endDate, period); + + const expectedStartTime = moment(new Date()).subtract(7, 'days'); + setTime(expectedStartTime, 0, 0, 0); + const expectedEndTime = moment(new Date()); + setTime(expectedEndTime, 23, 59, 59); + const expectedAction = buildExpectedPeriodChangeAction(expectedStartTime, expectedEndTime, LAST_WEEK); + + expect(results.type).to.equal(expectedAction.type); + validateDates(results.data.dateRange.startDate, expectedAction.data.dateRange.startDate); + validateDates(results.data.dateRange.endDate, expectedAction.data.dateRange.endDate); + expect(results.data.period).to.equal(expectedAction.data.period); + }); + it("Date Range Selector Action - test EVENT_PERIOD_CHANGE (period = Last Month)", function() { + var moment = require('moment'); + const startDate = moment(new Date()); + const endDate = moment(new Date()); + const period = LAST_MONTH; + + const results = DateRangeSelectorActions.onPeriodChange(startDate, endDate, period); + + const expectedStartTime = moment(new Date()).subtract(1, 'months'); + setTime(expectedStartTime, 0, 0, 0); + const expectedEndTime = moment(new Date()); + setTime(expectedEndTime, 23, 59, 59); + const expectedAction = buildExpectedPeriodChangeAction(expectedStartTime, expectedEndTime, LAST_MONTH); + + expect(results.type).to.equal(expectedAction.type); + validateDates(results.data.dateRange.startDate, expectedAction.data.dateRange.startDate); + validateDates(results.data.dateRange.endDate, expectedAction.data.dateRange.endDate); + expect(results.data.period).to.equal(expectedAction.data.period); + }); + it("Date Range Selector Action - test EVENT_PERIOD_CHANGE (period = Custom)", function() { + var moment = require('moment'); + const startDate = moment(new Date()).subtract(3, 'months'); + const endDate = moment(new Date()).add(6, 'days'); + const period = CUSTOM; + + const results = DateRangeSelectorActions.onPeriodChange(startDate, endDate, period); + + setTime(startDate, 0, 0, 0); + setTime(endDate, 23, 59, 59); + const expectedAction = buildExpectedPeriodChangeAction(startDate, endDate, CUSTOM); + + expect(results.type).to.equal(expectedAction.type); + validateDates(results.data.dateRange.startDate, expectedAction.data.dateRange.startDate); + validateDates(results.data.dateRange.endDate, expectedAction.data.dateRange.endDate); + expect(results.data.period).to.equal(expectedAction.data.period); + }); + it("Date Range Selector Action - test EVENT_PERIOD_CHANGE (period = Unknown)", function() { + var moment = require('moment'); + const startDate = moment(new Date()).subtract(3, 'months'); + const endDate = moment(new Date()).add(6, 'days'); + const period = 'Some Unknown Period'; + + const results = DateRangeSelectorActions.onPeriodChange(startDate, endDate, period); + + let expectedErrorMsg = ERROR_UNKNOWN_PERIOD + ': ' + period; + const expectedAction = buildExpectedUnknownPeriodAction(startDate, endDate, period, expectedErrorMsg); + + expect(results.type).to.deep.equal(expectedAction.type); + validateDates(results.data.dateRange.startDate, expectedAction.data.dateRange.startDate); + validateDates(results.data.dateRange.endDate, expectedAction.data.dateRange.endDate); + expect(results.data.period).to.equal(expectedAction.data.period); + }); + + // TODO - need tests to confirm DateRangeSelectorActions.onPeriodChange is called when clicking any of the 'quick link' periods + + + // helper functions + function setTime(moment, hours, minutes, seconds) { + moment.toDate(); + moment.hour(hours); + moment.minute(minutes); + moment.second(seconds); + } + + function validateDates(actualDate, expectedDates) { + expect(actualDate.toDate().getYear()).to.equal(expectedDates.toDate().getYear()); + expect(actualDate.toDate().getMonth()).to.equal(expectedDates.toDate().getMonth()); + expect(actualDate.toDate().getDay()).to.equal(expectedDates.toDate().getDay()); + expect(actualDate.toDate().getHours()).to.equal(expectedDates.toDate().getHours()); + expect(actualDate.toDate().getMinutes()).to.equal(expectedDates.toDate().getMinutes()); + } + + function buildExpectedPeriodChangeAction(start, end, period) { + return { + type: dateRangeSelectorActionTypes.EVENT_PERIOD_CHANGE, + data: { + dateRange: { + startDate: start, + endDate: end + }, + period: period + } + }; + } + + function buildExpectedUnknownPeriodAction(start, end, period, errorMsg) { + return { + type: dateRangeSelectorActionTypes.EVENT_PERIOD_ERROR, + data: { + dateRange: { + startDate: start, + endDate: end + }, + period: period, + errorMsg: errorMsg + } + }; + } +}); |