1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package org.orekit.propagation.events;
18
19 import org.hamcrest.CoreMatchers;
20 import org.hamcrest.MatcherAssert;
21 import org.hipparchus.CalculusFieldElement;
22 import org.hipparchus.Field;
23 import org.hipparchus.util.Binary64;
24 import org.hipparchus.util.Binary64Field;
25 import org.junit.jupiter.api.Assertions;
26 import org.junit.jupiter.api.Test;
27 import org.mockito.Mockito;
28 import org.orekit.propagation.FieldSpacecraftState;
29 import org.orekit.time.FieldAbsoluteDate;
30
31
32
33
34
35
36 class FieldNegateDetectorTest {
37
38 @Test
39 void testGetDetector() {
40
41 final FieldDateDetector<Binary64> expectedDetector = new FieldDateDetector<>(FieldAbsoluteDate.getArbitraryEpoch(Binary64Field.getInstance()));
42
43
44 final FieldNegateDetector<Binary64> negateDetector = new FieldNegateDetector<>(expectedDetector);
45
46
47 Assertions.assertEquals(expectedDetector, negateDetector.getDetector());
48 Assertions.assertEquals(expectedDetector, negateDetector.getOriginal());
49 }
50
51
52
53
54 @Test
55 void testG() {
56 doTestG(Binary64Field.getInstance());
57 }
58
59 private <T extends CalculusFieldElement<T>> void doTestG(final Field<T> field) {
60
61 @SuppressWarnings("unchecked")
62 FieldEventDetector<T> a = Mockito.mock(FieldEventDetector.class);
63 Mockito.when(a.getDetectionSettings()).thenReturn(new FieldEventDetectionSettings<>(field,
64 EventDetectionSettings.getDefaultEventDetectionSettings()));
65 FieldNegateDetector<T> detector = new FieldNegateDetector<>(a);
66 @SuppressWarnings("unchecked")
67 FieldSpacecraftState<T> s = Mockito.mock(FieldSpacecraftState.class);
68
69
70 Mockito.when(a.g(s)).thenReturn(field.getZero().newInstance(1.0));
71 MatcherAssert.assertThat(detector.g(s).getReal(), CoreMatchers.is(-1.0));
72
73 Mockito.when(a.g(s)).thenReturn(field.getZero().newInstance(-1.0));
74 MatcherAssert.assertThat(detector.g(s).getReal(), CoreMatchers.is(1.0));
75 }
76
77
78 @Test
79 void testCreate() {
80 doTestCreate(Binary64Field.getInstance());
81 }
82
83 private <T extends CalculusFieldElement<T>> void doTestCreate(final Field<T> field) {
84
85 @SuppressWarnings("unchecked")
86 FieldEventDetector<T> a = Mockito.mock(FieldEventDetector.class);
87 Mockito.when(a.getDetectionSettings()).thenReturn(new FieldEventDetectionSettings<>(field,
88 EventDetectionSettings.getDefaultEventDetectionSettings()));
89 FieldNegateDetector<T> detector = new FieldNegateDetector<>(a);
90
91
92 FieldNegateDetector<T> actual = detector.withMaxCheck(100);
93
94
95 MatcherAssert.assertThat(actual.getMaxCheckInterval().currentInterval(null, true), CoreMatchers.is(100.0));
96 Assertions.assertTrue(actual.getOriginal() == a);
97 }
98 }