diff --git a/client/core/src/drop-down/drop-down.spec.js b/client/core/src/drop-down/drop-down.spec.js
index 40944b872..4e2b8d5b9 100644
--- a/client/core/src/drop-down/drop-down.spec.js
+++ b/client/core/src/drop-down/drop-down.spec.js
@@ -12,7 +12,7 @@ describe('Component vnDropDown', () => {
beforeEach(angular.mock.inject((_$componentController_, _$timeout_, _$filter_) => {
$componentController = _$componentController_;
- $element = angular.element('
');
+ $element = angular.element('');
$timeout = _$timeout_;
$filter = _$filter_;
}));
@@ -268,7 +268,7 @@ describe('Component vnDropDown', () => {
expect(controller._activeOption).toEqual(0);
});
- it(`should call clearSearch() Esc key is pressed and take off 1 from _activeOption`, () => {
+ it(`should call clearSearch() Esc key is pressed and add up 1 to _activeOption`, () => {
let controller = $componentController('vnDropDown', {$element, $timeout, $filter});
controller.items = [{id: 1, name: 'Batman'}, {id: 2, name: 'Bruce'}, {id: 3, name: 'Logan'}, {id: 4, name: 'Wolverine'}];
spyOn(controller, 'setScrollPosition');
@@ -284,4 +284,77 @@ describe('Component vnDropDown', () => {
expect(controller._activeOption).toEqual(2);
});
});
+
+ describe('setScrollPosition()', () => {
+ it(`should call child.scrollIntoView if defined `, () => {
+ $element[0].firstChild.setAttribute('class', 'dropdown');
+ let child = $element[0].firstChild.firstChild;
+ child.scrollIntoView = () => {};
+ spyOn(child, 'scrollIntoView');
+ let controller = $componentController('vnDropDown', {$element, $timeout, $filter});
+ controller._activeOption = 0;
+ controller.setScrollPosition();
+
+ expect(child.scrollIntoView).toHaveBeenCalledWith();
+ });
+ });
+
+ describe('selectItem()', () => {
+ it(`should pass item to selected and set controller._show to false`, () => {
+ let controller = $componentController('vnDropDown', {$element, $timeout, $filter});
+ let item = {id: 1, name: 'Batman'};
+ controller.selectItem(item);
+
+ expect(controller.selected).toEqual(item);
+ expect(controller._show).toEqual(false);
+ });
+
+ it(`should pass item to selected and set controller._show to true if the controller.multiple is defined`, () => {
+ let controller = $componentController('vnDropDown', {$element, $timeout, $filter});
+ let item = {id: 1, name: 'Batman'};
+ controller.multiple = true;
+ controller.selectItem(item);
+
+ expect(controller.selected).toEqual(item);
+ expect(controller._show).toEqual(true);
+ });
+ });
+
+ describe('loadItems()', () => {
+ it(`should set controller._show to true`, () => {
+ let controller = $componentController('vnDropDown', {$element, $timeout, $filter});
+ controller.loadItems();
+
+ expect(controller._show).toEqual(true);
+ });
+
+ it(`should call loadMore() and then set controller._show to true`, () => {
+ let controller = $componentController('vnDropDown', {$element, $timeout, $filter}, {showLoadMore: () => {}, loadMore: () => {}});
+ spyOn(controller, 'loadMore');
+ controller.loadItems();
+
+ expect(controller._show).toEqual(true);
+ expect(controller.loadMore).toHaveBeenCalledWith();
+ });
+ });
+
+ describe('$onInit()', () => {
+ it(`should add an event listener to the parent element`, () => {
+ let controller = $componentController('vnDropDown', {$element, $timeout, $filter});
+ spyOn(controller.parent, 'addEventListener');
+ controller.$onInit();
+
+ expect(controller.parent.addEventListener).toHaveBeenCalledWith('keydown', jasmine.any(Function));
+ });
+ });
+
+ describe('$onDestroy()', () => {
+ it(`should remove an event listener from the parent element`, () => {
+ let controller = $componentController('vnDropDown', {$element, $timeout, $filter});
+ spyOn(controller.parent, 'removeEventListener');
+ controller.$onDestroy();
+
+ expect(controller.parent.removeEventListener).toHaveBeenCalledWith('keydown', jasmine.any(Function));
+ });
+ });
});