forked from mourner/suncalc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
test.js
89 lines (71 loc) · 2.86 KB
/
test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
var SunCalc = require('./suncalc'),
t = require('tap');
function near(val1, val2, margin) {
return Math.abs(val1 - val2) < (margin || 1E-15);
}
var date = new Date('2013-03-05UTC'),
lat = 50.5,
lng = 30.5,
height = 2000;
var testTimes = {
solarNoon: '2013-03-05T10:10:57Z',
nadir: '2013-03-04T22:10:57Z',
sunrise: '2013-03-05T04:34:56Z',
sunset: '2013-03-05T15:46:57Z',
sunriseEnd: '2013-03-05T04:38:19Z',
sunsetStart: '2013-03-05T15:43:34Z',
dawn: '2013-03-05T04:02:17Z',
dusk: '2013-03-05T16:19:36Z',
nauticalDawn: '2013-03-05T03:24:31Z',
nauticalDusk: '2013-03-05T16:57:22Z',
nightEnd: '2013-03-05T02:46:17Z',
night: '2013-03-05T17:35:36Z',
goldenHourEnd: '2013-03-05T05:19:01Z',
goldenHour: '2013-03-05T15:02:52Z'
};
var heightTestTimes = {
solarNoon: '2013-03-05T10:10:57Z',
nadir: '2013-03-04T22:10:57Z',
sunrise: '2013-03-05T04:25:07Z',
sunset: '2013-03-05T15:56:46Z'
};
t.test('getPosition returns azimuth and altitude for the given time and location', function (t) {
var sunPos = SunCalc.getPosition(date, lat, lng);
t.ok(near(sunPos.azimuth, -2.5003175907168385), 'azimuth');
t.ok(near(sunPos.altitude, -0.7000406838781611), 'altitude');
t.end();
});
t.test('getTimes returns sun phases for the given date and location', function (t) {
var times = SunCalc.getTimes(date, lat, lng);
for (var i in testTimes) {
t.equal(new Date(testTimes[i]).toUTCString(), times[i].toUTCString(), i);
}
t.end();
});
t.test('getTimes adjusts sun phases when additionally given the observer height', function (t) {
var times = SunCalc.getTimes(date, lat, lng, height);
for (var i in heightTestTimes) {
t.equal(new Date(heightTestTimes[i]).toUTCString(), times[i].toUTCString(), i);
}
t.end();
});
t.test('getMoonPosition returns moon position data given time and location', function (t) {
var moonPos = SunCalc.getMoonPosition(date, lat, lng);
t.ok(near(moonPos.azimuth, -0.9783999522438226), 'azimuth');
t.ok(near(moonPos.altitude, 0.014551482243892251), 'altitude');
t.ok(near(moonPos.distance, 364121.37256256194), 'distance');
t.end();
});
t.test('getMoonIllumination returns fraction and angle of moon\'s illuminated limb and phase', function (t) {
var moonIllum = SunCalc.getMoonIllumination(date);
t.ok(near(moonIllum.fraction, 0.4848068202456373), 'fraction');
t.ok(near(moonIllum.phase, 0.7548368838538762), 'phase');
t.ok(near(moonIllum.angle, 1.6732942678578346), 'angle');
t.end();
});
t.test('getMoonTimes returns moon rise and set times', function (t) {
var moonTimes = SunCalc.getMoonTimes(new Date('2013-03-04UTC'), lat, lng, true);
t.equal(moonTimes.rise.toUTCString(), 'Mon, 04 Mar 2013 23:54:29 GMT');
t.equal(moonTimes.set.toUTCString(), 'Mon, 04 Mar 2013 07:47:58 GMT');
t.end();
});