You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
267 lines
8.4 KiB
JavaScript
267 lines
8.4 KiB
JavaScript
import { Cartesian3 } from "../../Source/Cesium.js";
|
|
import { JulianDate } from "../../Source/Cesium.js";
|
|
import { ReferenceFrame } from "../../Source/Cesium.js";
|
|
import { TimeInterval } from "../../Source/Cesium.js";
|
|
import { TimeIntervalCollection } from "../../Source/Cesium.js";
|
|
import { PositionProperty } from "../../Source/Cesium.js";
|
|
import { TimeIntervalCollectionPositionProperty } from "../../Source/Cesium.js";
|
|
|
|
describe("DataSources/TimeIntervalCollectionPositionProperty", function () {
|
|
it("default constructor has expected values", function () {
|
|
var property = new TimeIntervalCollectionPositionProperty();
|
|
expect(property.intervals).toBeInstanceOf(TimeIntervalCollection);
|
|
expect(property.getValue(JulianDate.now())).toBeUndefined();
|
|
expect(property.referenceFrame).toBe(ReferenceFrame.FIXED);
|
|
});
|
|
|
|
it("getValue works without a result parameter", function () {
|
|
var interval1 = new TimeInterval({
|
|
start: new JulianDate(10, 0),
|
|
stop: new JulianDate(12, 0),
|
|
data: new Cartesian3(1, 2, 3),
|
|
});
|
|
var interval2 = new TimeInterval({
|
|
start: new JulianDate(12, 0),
|
|
stop: new JulianDate(14, 0),
|
|
isStartIncluded: false,
|
|
data: new Cartesian3(4, 5, 6),
|
|
});
|
|
|
|
var property = new TimeIntervalCollectionPositionProperty();
|
|
property.intervals.addInterval(interval1);
|
|
property.intervals.addInterval(interval2);
|
|
|
|
var result1 = property.getValue(interval1.start);
|
|
expect(result1).not.toBe(interval1.data);
|
|
expect(result1).toEqual(interval1.data);
|
|
|
|
var result2 = property.getValue(interval2.stop);
|
|
expect(result2).not.toBe(interval2.data);
|
|
expect(result2).toEqual(interval2.data);
|
|
});
|
|
|
|
it("getValue works with a result parameter", function () {
|
|
var interval1 = new TimeInterval({
|
|
start: new JulianDate(10, 0),
|
|
stop: new JulianDate(12, 0),
|
|
data: new Cartesian3(1, 2, 3),
|
|
});
|
|
var interval2 = new TimeInterval({
|
|
start: new JulianDate(12, 0),
|
|
stop: new JulianDate(14, 0),
|
|
isStartIncluded: false,
|
|
data: new Cartesian3(4, 5, 6),
|
|
});
|
|
|
|
var property = new TimeIntervalCollectionPositionProperty();
|
|
property.intervals.addInterval(interval1);
|
|
property.intervals.addInterval(interval2);
|
|
|
|
var expected = new Cartesian3();
|
|
var result1 = property.getValue(interval1.start, expected);
|
|
expect(result1).toBe(expected);
|
|
expect(result1).toEqual(interval1.data);
|
|
|
|
var result2 = property.getValue(interval2.stop, expected);
|
|
expect(result2).toBe(expected);
|
|
expect(result2).toEqual(interval2.data);
|
|
});
|
|
|
|
it("getValue returns in fixed frame", function () {
|
|
var interval1 = new TimeInterval({
|
|
start: new JulianDate(10, 0),
|
|
stop: new JulianDate(12, 0),
|
|
data: new Cartesian3(1, 2, 3),
|
|
});
|
|
|
|
var property = new TimeIntervalCollectionPositionProperty(
|
|
ReferenceFrame.INERTIAL
|
|
);
|
|
property.intervals.addInterval(interval1);
|
|
|
|
var valueInertial = new Cartesian3(1, 2, 3);
|
|
var valueFixed = PositionProperty.convertToReferenceFrame(
|
|
interval1.start,
|
|
valueInertial,
|
|
ReferenceFrame.INERTIAL,
|
|
ReferenceFrame.FIXED
|
|
);
|
|
|
|
var result = property.getValue(interval1.start);
|
|
expect(result).toEqual(valueFixed);
|
|
});
|
|
|
|
it("getValueInReferenceFrame works with a result parameter", function () {
|
|
var interval1 = new TimeInterval({
|
|
start: new JulianDate(10, 0),
|
|
stop: new JulianDate(12, 0),
|
|
data: new Cartesian3(1, 2, 3),
|
|
});
|
|
var interval2 = new TimeInterval({
|
|
start: new JulianDate(12, 0),
|
|
stop: new JulianDate(14, 0),
|
|
isStartIncluded: false,
|
|
data: new Cartesian3(4, 5, 6),
|
|
});
|
|
|
|
var property = new TimeIntervalCollectionPositionProperty(
|
|
ReferenceFrame.FIXED
|
|
);
|
|
property.intervals.addInterval(interval1);
|
|
property.intervals.addInterval(interval2);
|
|
|
|
var valueInertial = PositionProperty.convertToReferenceFrame(
|
|
interval1.start,
|
|
interval1.data,
|
|
ReferenceFrame.FIXED,
|
|
ReferenceFrame.INERTIAL
|
|
);
|
|
|
|
var expected = new Cartesian3();
|
|
var result1 = property.getValueInReferenceFrame(
|
|
interval1.start,
|
|
ReferenceFrame.INERTIAL,
|
|
expected
|
|
);
|
|
expect(result1).toBe(expected);
|
|
expect(result1).toEqual(valueInertial);
|
|
|
|
var result2 = property.getValueInReferenceFrame(
|
|
interval2.stop,
|
|
ReferenceFrame.FIXED,
|
|
expected
|
|
);
|
|
expect(result2).toBe(expected);
|
|
expect(result2).toEqual(interval2.data);
|
|
});
|
|
|
|
it("getValueInReferenceFrame works without a result parameter", function () {
|
|
var interval1 = new TimeInterval({
|
|
start: new JulianDate(10, 0),
|
|
stop: new JulianDate(12, 0),
|
|
data: new Cartesian3(1, 2, 3),
|
|
});
|
|
var interval2 = new TimeInterval({
|
|
start: new JulianDate(12, 0),
|
|
stop: new JulianDate(14, 0),
|
|
isStartIncluded: false,
|
|
data: new Cartesian3(4, 5, 6),
|
|
});
|
|
|
|
var property = new TimeIntervalCollectionPositionProperty(
|
|
ReferenceFrame.FIXED
|
|
);
|
|
property.intervals.addInterval(interval1);
|
|
property.intervals.addInterval(interval2);
|
|
|
|
var valueInertial = PositionProperty.convertToReferenceFrame(
|
|
interval1.start,
|
|
interval1.data,
|
|
ReferenceFrame.FIXED,
|
|
ReferenceFrame.INERTIAL
|
|
);
|
|
|
|
var result1 = property.getValueInReferenceFrame(
|
|
interval1.start,
|
|
ReferenceFrame.INERTIAL
|
|
);
|
|
expect(result1).toEqual(valueInertial);
|
|
|
|
var result2 = property.getValueInReferenceFrame(
|
|
interval2.stop,
|
|
ReferenceFrame.FIXED
|
|
);
|
|
expect(result2).toEqual(interval2.data);
|
|
});
|
|
|
|
it("returns undefined for valid interval without data", function () {
|
|
var property = new TimeIntervalCollectionPositionProperty();
|
|
|
|
var interval = new TimeInterval({
|
|
start: new JulianDate(10, 0),
|
|
stop: new JulianDate(12, 0),
|
|
});
|
|
property.intervals.addInterval(interval);
|
|
|
|
var result = property.getValue(interval.start);
|
|
expect(result).toBeUndefined();
|
|
});
|
|
|
|
it("throws with no time parameter", function () {
|
|
var property = new TimeIntervalCollectionPositionProperty();
|
|
expect(function () {
|
|
property.getValue(undefined);
|
|
}).toThrowDeveloperError();
|
|
});
|
|
|
|
it("throws with no reference frame parameter", function () {
|
|
var property = new TimeIntervalCollectionPositionProperty();
|
|
var time = JulianDate.now();
|
|
expect(function () {
|
|
property.getValueInReferenceFrame(time, undefined);
|
|
}).toThrowDeveloperError();
|
|
});
|
|
|
|
it("equals works for differing referenceFrames", function () {
|
|
var left = new TimeIntervalCollectionPositionProperty(ReferenceFrame.FIXED);
|
|
var right = new TimeIntervalCollectionPositionProperty(
|
|
ReferenceFrame.INERTIAL
|
|
);
|
|
expect(left.equals(right)).toEqual(false);
|
|
|
|
right = new TimeIntervalCollectionPositionProperty(ReferenceFrame.FIXED);
|
|
expect(left.equals(right)).toEqual(true);
|
|
});
|
|
|
|
it("equals works for differing intervals", function () {
|
|
var interval1 = new TimeInterval({
|
|
start: new JulianDate(10, 0),
|
|
stop: new JulianDate(12, 0),
|
|
data: new Cartesian3(1, 2, 3),
|
|
});
|
|
var interval2 = new TimeInterval({
|
|
start: new JulianDate(12, 0),
|
|
stop: new JulianDate(14, 0),
|
|
isStartIncluded: false,
|
|
data: new Cartesian3(4, 5, 6),
|
|
});
|
|
|
|
var left = new TimeIntervalCollectionPositionProperty(ReferenceFrame.FIXED);
|
|
left.intervals.addInterval(interval1);
|
|
left.intervals.addInterval(interval2);
|
|
|
|
var right = new TimeIntervalCollectionPositionProperty(
|
|
ReferenceFrame.FIXED
|
|
);
|
|
right.intervals.addInterval(interval1);
|
|
|
|
expect(left.equals(right)).toEqual(false);
|
|
right.intervals.addInterval(interval2);
|
|
expect(left.equals(right)).toEqual(true);
|
|
});
|
|
|
|
it("raises definitionChanged event", function () {
|
|
var interval = new TimeInterval({
|
|
start: new JulianDate(10, 0),
|
|
stop: new JulianDate(12, 0),
|
|
data: new Cartesian3(1, 2, 3),
|
|
});
|
|
|
|
var property = new TimeIntervalCollectionPositionProperty();
|
|
var listener = jasmine.createSpy("listener");
|
|
property.definitionChanged.addEventListener(listener);
|
|
|
|
property.intervals.addInterval(interval);
|
|
expect(listener).toHaveBeenCalledWith(property);
|
|
listener.calls.reset();
|
|
|
|
property.intervals.removeInterval(interval);
|
|
expect(listener).toHaveBeenCalledWith(property);
|
|
|
|
property.intervals.addInterval(interval);
|
|
listener.calls.reset();
|
|
property.intervals.removeAll();
|
|
expect(listener).toHaveBeenCalledWith(property);
|
|
});
|
|
});
|