UNPKG

20.8 kBJavaScriptView Raw
1"use strict";
2var infinite_scroll_1 = require('./infinite-scroll');
3var core_1 = require('@angular/core');
4describe('Infinite Scroll Directive', function () {
5 // const zone = new NgZone({ enableLongStackTrace: false });
6 var isScrollingDown = true;
7 var zoneSpy, scrollResolverSpy, scrollRegisterSpy, positionResolverSpy;
8 var positionFactoryMock = {
9 create: function () { return positionResolverSpy; }
10 };
11 var createMockElement = function () {
12 var mockedElement = new core_1.ElementRef(document.createElement('div'));
13 return mockedElement;
14 };
15 var createInfiniteScroll = function (mockedElement) {
16 mockedElement = mockedElement || createMockElement();
17 return new infinite_scroll_1.InfiniteScroll(mockedElement, zoneSpy, positionFactoryMock, scrollRegisterSpy, scrollResolverSpy);
18 };
19 beforeEach(function () {
20 zoneSpy = jasmine.createSpyObj('zone', ['run']);
21 scrollResolverSpy = {
22 getScrollStats: function () {
23 return { shouldScroll: true, isScrollingDown: isScrollingDown };
24 }
25 };
26 scrollRegisterSpy = jasmine.createSpyObj('register', ['attachEvent']);
27 positionResolverSpy = jasmine.createSpyObj('pos', ['create', 'container']);
28 });
29 it('should create an instance of the directive', function () {
30 var actual = createInfiniteScroll();
31 expect(actual).toBeDefined();
32 });
33 it('should have default @Input properties values', function () {
34 var directive = createInfiniteScroll();
35 var expectedInputs = {
36 _distanceDown: 2,
37 _distanceUp: 1.5,
38 _throttle: 300,
39 scrollWindow: true,
40 _immediate: false,
41 _horizontal: false,
42 _alwaysCallback: false,
43 _disabled: false,
44 _container: null
45 };
46 Object.keys(expectedInputs).forEach(function (input) {
47 return expect(directive[input]).toEqual(expectedInputs[input]);
48 });
49 });
50 it('should trigger the onScrollDown event when scroll has passed _distancedDown', function () {
51 var directive = createInfiniteScroll();
52 var container = {
53 height: 0,
54 scrolledUntilNow: 0,
55 totalToScroll: 0,
56 };
57 spyOn(directive, 'onScrollDown');
58 directive.ngOnInit();
59 directive.handleOnScroll(container);
60 var actual = directive.onScrollDown;
61 expect(actual).toHaveBeenCalled();
62 });
63 it('should trigger the onScrollUp event when scroll has passed _distanceUp', function () {
64 var directive = createInfiniteScroll();
65 var container = {
66 height: 0,
67 scrolledUntilNow: 0,
68 totalToScroll: 0,
69 };
70 spyOn(directive, 'onScrollUp');
71 directive.ngOnInit();
72 isScrollingDown = false;
73 directive.handleOnScroll(container);
74 var actual = directive.onScrollUp;
75 expect(actual).toHaveBeenCalled();
76 });
77 it('should disable the scroller', function () {
78 var directive = createInfiniteScroll();
79 var container = {
80 height: 0,
81 scrolledUntilNow: 0,
82 totalToScroll: 0,
83 };
84 spyOn(directive, 'onScrollDown');
85 directive.ngOnInit();
86 directive._disabled = true;
87 directive.handleOnScroll(container);
88 var actual = directive.onScrollDown;
89 expect(actual).not.toHaveBeenCalled();
90 });
91 describe('resolving container', function () {
92 var directive;
93 var mockedElement;
94 var container = {
95 height: 0,
96 scrolledUntilNow: 0,
97 totalToScroll: 0,
98 };
99 beforeEach(function () {
100 mockedElement = createMockElement();
101 directive = createInfiniteScroll(mockedElement);
102 spyOn(positionFactoryMock, 'create').and.callThrough();
103 });
104 describe('when container input is defined', function () {
105 describe('when css selector is used', function () {
106 beforeEach(function () {
107 spyOn(document, 'querySelector').and.returnValue(container);
108 directive._container = '.test';
109 directive.ngOnInit();
110 });
111 it('should find element in DOM', function () {
112 expect(document.querySelector).toHaveBeenCalledWith('.test');
113 });
114 it('should return container', function () {
115 expect(positionFactoryMock.create)
116 .toHaveBeenCalledWith(jasmine.objectContaining({ windowElement: container }));
117 });
118 });
119 describe('when container is passed directly', function () {
120 beforeEach(function () {
121 directive._container = container;
122 directive.ngOnInit();
123 });
124 it('should return container', function () {
125 expect(positionFactoryMock.create)
126 .toHaveBeenCalledWith(jasmine.objectContaining({ windowElement: container }));
127 });
128 });
129 });
130 describe('when container input is not defined', function () {
131 describe('when scrollWindow is true', function () {
132 beforeEach(function () {
133 directive.scrollWindow = true;
134 directive.ngOnInit();
135 });
136 it('should return window', function () {
137 expect(positionFactoryMock.create)
138 .toHaveBeenCalledWith(jasmine.objectContaining({ windowElement: window }));
139 });
140 });
141 describe('when scrollWindow is false', function () {
142 beforeEach(function () {
143 directive.scrollWindow = false;
144 directive.ngOnInit();
145 });
146 it('should return current element', function () {
147 expect(positionFactoryMock.create)
148 .toHaveBeenCalledWith(jasmine.objectContaining({ windowElement: mockedElement }));
149 });
150 });
151 });
152 });
153});
154//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infinite-scroll.spec.js","sourceRoot":"","sources":["infinite-scroll.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  async,\n  inject\n} from '@angular/core/testing';\nimport { InfiniteScroll } from './infinite-scroll';\nimport { AxisResolverFactory } from './axis-resolver';\nimport { PositionResolverFactory } from './position-resolver';\nimport { ScrollRegister } from './scroll-register';\nimport { ScrollResolver } from './scroll-resolver';\n\nimport { ElementRef, NgZone, SimpleChanges, SimpleChange } from '@angular/core';\n\ndescribe('Infinite Scroll Directive', () => {\n  // const zone = new NgZone({ enableLongStackTrace: false });\n  let isScrollingDown = true;\n  let zoneSpy: any, scrollResolverSpy: any, scrollRegisterSpy: any, positionResolverSpy: any;\n  const positionFactoryMock: any =  {\n    create: () => positionResolverSpy\n  };\n  const createMockElement = () => {\n    const mockedElement: ElementRef = new ElementRef(document.createElement('div'));\n    return mockedElement;\n  };\n  const createInfiniteScroll = (mockedElement?: any) => {\n    mockedElement = mockedElement || createMockElement();\n    return new InfiniteScroll(\n      mockedElement,\n      zoneSpy,\n      positionFactoryMock,\n      scrollRegisterSpy,\n      scrollResolverSpy\n    );\n  };\n\n  beforeEach(() =>{\n    zoneSpy = jasmine.createSpyObj('zone', ['run']);\n    scrollResolverSpy = {\n      getScrollStats: () => {\n        return { shouldScroll: true, isScrollingDown };\n      }\n    };\n    scrollRegisterSpy = jasmine.createSpyObj('register', ['attachEvent'])\n    positionResolverSpy = jasmine.createSpyObj('pos', ['create', 'container']);\n  });\n\n  it('should create an instance of the directive', () => {\n    const actual = createInfiniteScroll();\n    expect(actual).toBeDefined();\n  });\n\n  it('should have default @Input properties values', () => {\n    const directive = createInfiniteScroll();\n    const expectedInputs: Object = {\n      _distanceDown: 2,\n      _distanceUp: 1.5,\n      _throttle: 300,\n      scrollWindow: true,\n      _immediate: false,\n      _horizontal: false,\n      _alwaysCallback: false,\n      _disabled: false,\n      _container: null\n    };\n\n    Object.keys(expectedInputs).forEach(input =>\n      expect(directive[input]).toEqual(expectedInputs[input]));\n  });\n\n  it('should trigger the onScrollDown event when scroll has passed _distancedDown', () => {\n    const directive = createInfiniteScroll();\n    const container = {\n      height: 0,\n      scrolledUntilNow: 0,\n      totalToScroll: 0,\n    }\n    spyOn(directive, 'onScrollDown');\n    directive.ngOnInit();\n    directive.handleOnScroll(container)\n    const actual = directive.onScrollDown;\n    expect(actual).toHaveBeenCalled();\n  });\n\n  it('should trigger the onScrollUp event when scroll has passed _distanceUp', () => {\n    const directive = createInfiniteScroll();\n    const container = {\n      height: 0,\n      scrolledUntilNow: 0,\n      totalToScroll: 0,\n    };\n    spyOn(directive, 'onScrollUp');\n    directive.ngOnInit();\n    isScrollingDown = false;\n    directive.handleOnScroll(container);\n    const actual = directive.onScrollUp;\n    expect(actual).toHaveBeenCalled();\n  });\n\n  it('should disable the scroller', () => {\n    const directive = createInfiniteScroll();\n    const container = {\n      height: 0,\n      scrolledUntilNow: 0,\n      totalToScroll: 0,\n    }\n    spyOn(directive, 'onScrollDown');\n    directive.ngOnInit();\n    directive._disabled = true;\n    directive.handleOnScroll(container);\n    const actual = directive.onScrollDown;\n    expect(actual).not.toHaveBeenCalled();\n  });\n\n  describe('resolving container', () => {\n    let directive: InfiniteScroll;\n    let mockedElement: ElementRef;\n    const container = {\n      height: 0,\n      scrolledUntilNow: 0,\n      totalToScroll: 0,\n    };\n\n    beforeEach(() => {\n      mockedElement = createMockElement();\n      directive = createInfiniteScroll(mockedElement);\n      spyOn(positionFactoryMock, 'create').and.callThrough();\n    });\n\n    describe('when container input is defined', () => {\n      describe('when css selector is used', () => {\n        beforeEach(() => {\n          spyOn(document, 'querySelector').and.returnValue(container);\n          directive._container = '.test';\n          directive.ngOnInit();\n        });\n\n        it('should find element in DOM', () => {\n          expect(document.querySelector).toHaveBeenCalledWith('.test');\n        });\n\n        it('should return container', () => {\n          expect(positionFactoryMock.create)\n              .toHaveBeenCalledWith(jasmine.objectContaining({windowElement: container}));\n        });\n      });\n\n      describe('when container is passed directly', () => {\n        beforeEach(() => {\n          directive._container = container;\n          directive.ngOnInit();\n        });\n\n        it('should return container', () => {\n          expect(positionFactoryMock.create)\n              .toHaveBeenCalledWith(jasmine.objectContaining({windowElement: container}));\n        });\n      });\n    });\n\n    describe('when container input is not defined', () => {\n      describe('when scrollWindow is true', () => {\n        beforeEach(() => {\n          directive.scrollWindow = true;\n          directive.ngOnInit();\n        });\n\n        it('should return window', () => {\n          expect(positionFactoryMock.create)\n              .toHaveBeenCalledWith(jasmine.objectContaining({windowElement: window}));\n        });\n      });\n\n      describe('when scrollWindow is false', () => {\n        beforeEach(() => {\n          directive.scrollWindow = false;\n          directive.ngOnInit();\n        });\n\n        it('should return current element', () => {\n          expect(positionFactoryMock.create)\n              .toHaveBeenCalledWith(jasmine.objectContaining({windowElement: mockedElement}));\n        });\n      });\n    });\n  });\n});\n\ninterface DecoratorInvocation {\n  type: Function;\n  args?: any[];\n}\n"]}
\No newline at end of file