2015-08-18 10:16:30 -04:00
|
|
|
import {
|
|
|
|
ddescribe,
|
|
|
|
describe,
|
|
|
|
it,
|
|
|
|
iit,
|
|
|
|
xit,
|
|
|
|
expect,
|
|
|
|
beforeEach,
|
|
|
|
afterEach,
|
2015-08-24 09:41:36 -04:00
|
|
|
browserDetection
|
2015-08-18 10:16:30 -04:00
|
|
|
} from 'angular2/test_lib';
|
2015-07-04 14:04:54 -04:00
|
|
|
|
2015-08-07 14:41:38 -04:00
|
|
|
import {DatePipe} from 'angular2/pipes';
|
2015-08-20 17:28:25 -04:00
|
|
|
import {DateWrapper} from 'angular2/src/core/facade/lang';
|
2015-07-04 14:04:54 -04:00
|
|
|
|
|
|
|
export function main() {
|
|
|
|
describe("DatePipe", () => {
|
|
|
|
var date;
|
|
|
|
var pipe;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
date = DateWrapper.create(2015, 6, 15, 21, 43, 11);
|
|
|
|
pipe = new DatePipe();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe("supports", () => {
|
|
|
|
it("should support date", () => { expect(pipe.supports(date)).toBe(true); });
|
|
|
|
it("should support int", () => { expect(pipe.supports(123456789)).toBe(true); });
|
|
|
|
|
|
|
|
it("should not support other objects", () => {
|
|
|
|
expect(pipe.supports(new Object())).toBe(false);
|
|
|
|
expect(pipe.supports(null)).toBe(false);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
2015-08-18 10:16:30 -04:00
|
|
|
// TODO(mlaval): enable tests when Intl API is no longer used, see
|
|
|
|
// https://github.com/angular/angular/issues/3333
|
2015-08-24 09:41:36 -04:00
|
|
|
if (browserDetection.supportsIntlApi) {
|
2015-08-18 10:16:30 -04:00
|
|
|
describe("transform", () => {
|
|
|
|
it('should format each component correctly', () => {
|
|
|
|
expect(pipe.transform(date, ['y'])).toEqual('2015');
|
|
|
|
expect(pipe.transform(date, ['yy'])).toEqual('15');
|
|
|
|
expect(pipe.transform(date, ['M'])).toEqual('6');
|
|
|
|
expect(pipe.transform(date, ['MM'])).toEqual('06');
|
|
|
|
expect(pipe.transform(date, ['MMM'])).toEqual('Jun');
|
|
|
|
expect(pipe.transform(date, ['MMMM'])).toEqual('June');
|
|
|
|
expect(pipe.transform(date, ['d'])).toEqual('15');
|
|
|
|
expect(pipe.transform(date, ['E'])).toEqual('Mon');
|
|
|
|
expect(pipe.transform(date, ['EEEE'])).toEqual('Monday');
|
|
|
|
expect(pipe.transform(date, ['H'])).toEqual('21');
|
|
|
|
expect(pipe.transform(date, ['j'])).toEqual('9 PM');
|
|
|
|
expect(pipe.transform(date, ['m'])).toEqual('43');
|
|
|
|
expect(pipe.transform(date, ['s'])).toEqual('11');
|
|
|
|
});
|
2015-07-04 14:04:54 -04:00
|
|
|
|
2015-08-18 10:16:30 -04:00
|
|
|
it('should format common multi component patterns', () => {
|
|
|
|
expect(pipe.transform(date, ['yMEd'])).toEqual('Mon, 6/15/2015');
|
|
|
|
expect(pipe.transform(date, ['MEd'])).toEqual('Mon, 6/15');
|
|
|
|
expect(pipe.transform(date, ['MMMd'])).toEqual('Jun 15');
|
|
|
|
expect(pipe.transform(date, ['yMMMMEEEEd'])).toEqual('Monday, June 15, 2015');
|
|
|
|
expect(pipe.transform(date, ['jms'])).toEqual('9:43:11 PM');
|
|
|
|
expect(pipe.transform(date, ['ms'])).toEqual('43:11');
|
|
|
|
});
|
2015-07-04 14:04:54 -04:00
|
|
|
|
2015-08-18 10:16:30 -04:00
|
|
|
it('should format with pattern aliases', () => {
|
|
|
|
expect(pipe.transform(date, ['medium'])).toEqual('Jun 15, 2015, 9:43:11 PM');
|
|
|
|
expect(pipe.transform(date, ['short'])).toEqual('6/15/2015, 9:43 PM');
|
|
|
|
expect(pipe.transform(date, ['fullDate'])).toEqual('Monday, June 15, 2015');
|
|
|
|
expect(pipe.transform(date, ['longDate'])).toEqual('June 15, 2015');
|
|
|
|
expect(pipe.transform(date, ['mediumDate'])).toEqual('Jun 15, 2015');
|
|
|
|
expect(pipe.transform(date, ['shortDate'])).toEqual('6/15/2015');
|
|
|
|
expect(pipe.transform(date, ['mediumTime'])).toEqual('9:43:11 PM');
|
|
|
|
expect(pipe.transform(date, ['shortTime'])).toEqual('9:43 PM');
|
|
|
|
});
|
2015-07-04 14:04:54 -04:00
|
|
|
});
|
2015-08-18 10:16:30 -04:00
|
|
|
}
|
2015-07-04 14:04:54 -04:00
|
|
|
});
|
|
|
|
}
|