diff --git a/rugged-core/src/main/java/org/orekit/rugged/core/RuggedImpl.java b/rugged-core/src/main/java/org/orekit/rugged/core/RuggedImpl.java
index bd9708711ca7f385fdbbab5dfc58554e498f1fc9..83d2b27d381d68176703b414e724ed38108a5b54 100644
--- a/rugged-core/src/main/java/org/orekit/rugged/core/RuggedImpl.java
+++ b/rugged-core/src/main/java/org/orekit/rugged/core/RuggedImpl.java
@@ -164,6 +164,13 @@ public class RuggedImpl implements Rugged {
         }
     }
 
+    /** Get the reference date.
+     * @return reference date
+     */
+    public AbsoluteDate getReferenceDate() {
+        return referenceDate;
+    }
+
     /** {@inheritDoc} */
     @Override
     public void setUpTilesManagement(TileUpdater updater, int maxCachedTiles) {
diff --git a/rugged-core/src/test/java/org/orekit/rugged/core/RuggedImplTest.java b/rugged-core/src/test/java/org/orekit/rugged/core/RuggedImplTest.java
index 270dafe1a65c65b6d12d57a00156cb1d60ca28f6..347cf052192034579221c5bebda6b0a6988490fa 100644
--- a/rugged-core/src/test/java/org/orekit/rugged/core/RuggedImplTest.java
+++ b/rugged-core/src/test/java/org/orekit/rugged/core/RuggedImplTest.java
@@ -19,11 +19,12 @@ package org.orekit.rugged.core;
 
 import java.io.File;
 import java.net.URISyntaxException;
+import java.util.Arrays;
+import java.util.List;
 
 import org.apache.commons.math3.ode.nonstiff.DormandPrince853Integrator;
 import org.apache.commons.math3.util.FastMath;
 import org.junit.Assert;
-import org.junit.Before;
 import org.junit.Test;
 import org.orekit.attitudes.AttitudeProvider;
 import org.orekit.attitudes.NadirPointing;
@@ -36,7 +37,6 @@ import org.orekit.errors.OrekitException;
 import org.orekit.forces.gravity.HolmesFeatherstoneAttractionModel;
 import org.orekit.forces.gravity.ThirdBodyAttraction;
 import org.orekit.forces.gravity.potential.GravityFieldFactory;
-import org.orekit.forces.gravity.potential.ICGEMFormatReader;
 import org.orekit.forces.gravity.potential.NormalizedSphericalHarmonicsProvider;
 import org.orekit.frames.Frame;
 import org.orekit.frames.FramesFactory;
@@ -48,6 +48,8 @@ import org.orekit.propagation.SpacecraftState;
 import org.orekit.propagation.numerical.NumericalPropagator;
 import org.orekit.rugged.api.Rugged;
 import org.orekit.rugged.api.RuggedException;
+import org.orekit.rugged.api.SatellitePV;
+import org.orekit.rugged.api.SatelliteQ;
 import org.orekit.time.AbsoluteDate;
 import org.orekit.time.TimeScalesFactory;
 import org.orekit.utils.Constants;
@@ -56,24 +58,93 @@ import org.orekit.utils.IERSConventions;
 public class RuggedImplTest {
 
     @Test
-    public void testSetContext() throws RuggedException, OrekitException {
+    public void testSetContextWithoutOrekit()
+        throws RuggedException, OrekitException, URISyntaxException {
+
+        List<SatellitePV> pv = Arrays.asList(
+            new SatellitePV( 0.000, -1545168.478, -7001985.361,       0.000, -1095.152224, 231.344922, -7372.851944),
+            new SatellitePV( 1.000, -1546262.794, -7001750.226,   -7372.851, -1093.478904, 238.925123, -7372.847995),
+            new SatellitePV( 2.000, -1547355.435, -7001507.511,  -14745.693, -1091.804408, 246.505033, -7372.836044),
+            new SatellitePV( 3.000, -1548446.402, -7001257.216,  -22118.520, -1090.128736, 254.084644, -7372.816090),
+            new SatellitePV( 4.000, -1549535.693, -7000999.342,  -29491.323, -1088.451892, 261.663949, -7372.788133),
+            new SatellitePV( 5.000, -1550623.306, -7000733.888,  -36864.094, -1086.773876, 269.242938, -7372.752175),
+            new SatellitePV( 6.000, -1551709.240, -7000460.856,  -44236.825, -1085.094690, 276.821604, -7372.708214),
+            new SatellitePV( 7.000, -1552793.495, -7000180.245,  -51609.507, -1083.414336, 284.399938, -7372.656251),
+            new SatellitePV( 8.000, -1553876.068, -6999892.056,  -58982.134, -1081.732817, 291.977932, -7372.596287),
+            new SatellitePV( 9.000, -1554956.960, -6999596.289,  -66354.697, -1080.050134, 299.555578, -7372.528320),
+            new SatellitePV(10.000, -1556036.168, -6999292.945,  -73727.188, -1078.366288, 307.132868, -7372.452352),
+            new SatellitePV(11.000, -1557113.692, -6998982.024,  -81099.599, -1076.681282, 314.709792, -7372.368382),
+            new SatellitePV(12.000, -1558189.530, -6998663.526,  -88471.922, -1074.995118, 322.286344, -7372.276411),
+            new SatellitePV(13.000, -1559263.682, -6998337.451,  -95844.150, -1073.307797, 329.862513, -7372.176439),
+            new SatellitePV(14.000, -1560336.145, -6998003.801, -103216.273, -1071.619321, 337.438294, -7372.068466),
+            new SatellitePV(15.000, -1561406.920, -6997662.575, -110588.284, -1069.929692, 345.013676, -7371.952492),
+            new SatellitePV(16.000, -1562476.004, -6997313.774, -117960.175, -1068.238912, 352.588652, -7371.828517),
+            new SatellitePV(17.000, -1563543.398, -6996957.398, -125331.938, -1066.546983, 360.163213, -7371.696542),
+            new SatellitePV(18.000, -1564609.098, -6996593.447, -132703.565, -1064.853906, 367.737352, -7371.556566),
+            new SatellitePV(19.000, -1565673.105, -6996221.923, -140075.049, -1063.159684, 375.311060, -7371.408591),
+            new SatellitePV(20.000, -1566735.417, -6995842.825, -147446.380, -1061.464319, 382.884328, -7371.252616));
+        List<SatelliteQ> q = Arrays.asList(
+            new SatelliteQ( 0.000, 0.516354347549, -0.400120145429,  0.583012133139,  0.483093065155),
+            new SatelliteQ( 1.000, 0.516659035405, -0.399867643627,  0.582741754688,  0.483302551263),
+            new SatelliteQ( 2.000, 0.516963581177, -0.399615033309,  0.582471217473,  0.483511904409),
+            new SatelliteQ( 3.000, 0.517267984776, -0.399362314553,  0.582200521577,  0.483721124530),
+            new SatelliteQ( 4.000, 0.517572246112, -0.399109487434,  0.581929667081,  0.483930211565),
+            new SatelliteQ( 5.000, 0.517876365096, -0.398856552030,  0.581658654071,  0.484139165451),
+            new SatelliteQ( 6.000, 0.518180341637, -0.398603508416,  0.581387482627,  0.484347986126),
+            new SatelliteQ( 7.000, 0.518484175647, -0.398350356669,  0.581116152834,  0.484556673529),
+            new SatelliteQ( 8.000, 0.518787867035, -0.398097096866,  0.580844664773,  0.484765227599),
+            new SatelliteQ( 9.000, 0.519091415713, -0.397843729083,  0.580573018530,  0.484973648272),
+            new SatelliteQ(10.000, 0.519394821590, -0.397590253397,  0.580301214186,  0.485181935488),
+            new SatelliteQ(11.000, 0.519698084578, -0.397336669885,  0.580029251825,  0.485390089185),
+            new SatelliteQ(12.000, 0.520001204587, -0.397082978623,  0.579757131530,  0.485598109301),
+            new SatelliteQ(13.000, 0.520304181527, -0.396829179688,  0.579484853385,  0.485805995775),
+            new SatelliteQ(14.000, 0.520607015311, -0.396575273158,  0.579212417473,  0.486013748545),
+            new SatelliteQ(15.000, 0.520909705847, -0.396321259108,  0.578939823877,  0.486221367550),
+            new SatelliteQ(16.000, 0.521212253049, -0.396067137616,  0.578667072681,  0.486428852729),
+            new SatelliteQ(17.000, 0.521514656825, -0.395812908759,  0.578394163969,  0.486636204020),
+            new SatelliteQ(18.000, 0.521816917089, -0.395558572613,  0.578121097824,  0.486843421362),
+            new SatelliteQ(19.000, 0.522119033749, -0.395304129256,  0.577847874330,  0.487050504694),
+            new SatelliteQ(20.000, 0.522421006719, -0.395049578765,  0.577574493570,  0.487257453954));
+        String path = getClass().getClassLoader().getResource("orekit-data").toURI().getPath();
         RuggedImpl rugged = new RuggedImpl();
-        rugged.setGeneralContext(null,
-                                 propagator.getInitialState().getDate(),
+        rugged.setGeneralContext(new File(path),
+                                 "2012-01-01T00:00:00",
                                  Rugged.Algorithm.DUVENHAGE,
                                  Rugged.Ellipsoid.WGS84,
                                  Rugged.InertialFrame.EME2000,
                                  Rugged.BodyRotatingFrame.ITRF,
-                                 propagator);
+                                 pv, 8, q, 8);
+
+        Assert.assertEquals(new AbsoluteDate("2012-01-01T00:00:00", TimeScalesFactory.getUTC()),
+                            rugged.getReferenceDate());
+
     }
 
-    @Before
-    public void setUp() throws RuggedException, OrekitException, URISyntaxException {
+    @Test
+    public void testSetContextWithOrekit()
+        throws RuggedException, OrekitException, URISyntaxException {
 
         String path = getClass().getClassLoader().getResource("orekit-data").toURI().getPath();
         DataProvidersManager.getInstance().addProvider(new DirectoryCrawler(new File(path)));
+        Propagator propagator = createPropagator();
+
+        RuggedImpl rugged = new RuggedImpl();
+        rugged.setGeneralContext(null,
+                                 propagator.getInitialState().getDate(),
+                                 Rugged.Algorithm.DUVENHAGE,
+                                 Rugged.Ellipsoid.WGS84,
+                                 Rugged.InertialFrame.EME2000,
+                                 Rugged.BodyRotatingFrame.ITRF,
+                                 propagator);
 
-        // the following orbital parameters have been computed using
+        Assert.assertEquals(propagator.getInitialState().getDate(), rugged.getReferenceDate());
+
+    }
+
+   private Propagator createPropagator()
+       throws OrekitException {
+
+       // the following orbital parameters have been computed using
         // Orekit tutorial about phasing, using the following configuration:
         //
         //  orbit.date                          = 2012-01-01T00:00:00.000
@@ -115,10 +186,9 @@ public class RuggedImplTest {
         numericalPropagator.addForceModel(new ThirdBodyAttraction(CelestialBodyFactory.getMoon()));
         numericalPropagator.setOrbitType(type);
         numericalPropagator.setInitialState(state);
-        propagator = numericalPropagator;
+        numericalPropagator.setAttitudeProvider(provider);
+        return numericalPropagator;
 
     }
 
-    Propagator propagator;
-
 }