import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.node.ObjectNode;
-import java.util.Arrays;
import java.util.Iterator;
import java.util.Map;
import java.util.Optional;
import org.opendaylight.mdsal.dom.api.DOMMountPointService;
import org.opendaylight.mdsal.dom.api.DOMSchemaService;
import org.opendaylight.netconf.sal.rest.doc.impl.ApiDocServiceImpl.OAversion;
-import org.opendaylight.netconf.sal.rest.doc.impl.ApiDocServiceImpl.URIType;
-import org.opendaylight.netconf.sal.rest.doc.impl.MountPointSwaggerGeneratorDraft02;
+import org.opendaylight.netconf.sal.rest.doc.impl.MountPointSwaggerGeneratorRFC8040;
import org.opendaylight.netconf.sal.rest.doc.mountpoints.MountPointSwagger;
import org.opendaylight.netconf.sal.rest.doc.swagger.SwaggerObject;
import org.opendaylight.yangtools.yang.common.QName;
import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier;
-import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext;
-import org.opendaylight.yangtools.yang.test.util.YangParserTestUtils;
-public final class MountPointSwaggerTest {
+public final class MountPointSwaggerTest extends AbstractApiDocTest {
private static final String HTTP_URL = "http://localhost/path";
private static final YangInstanceIdentifier INSTANCE_ID = YangInstanceIdentifier.builder()
.node(QName.create("", "nodes"))
.node(QName.create("", "node"))
.nodeWithKey(QName.create("", "node"), QName.create("", "id"), "123").build();
- private static final String INSTANCE_URL = "/nodes/node/123/";
+ private static final String INSTANCE_URL = "/nodes/node=123/";
private MountPointSwagger swagger;
@Before
- public void setUp() {
+ public void before() {
// We are sharing the global schema service and the mount schema service
// in our test.
// OK for testing - real thing would have separate instances.
- final EffectiveModelContext context = YangParserTestUtils.parseYangResourceDirectory("/yang");
- final DOMSchemaService schemaService = DocGenTestHelper.createMockSchemaService(context);
-
final DOMMountPoint mountPoint = mock(DOMMountPoint.class);
- when(mountPoint.getService(DOMSchemaService.class)).thenReturn(Optional.of(schemaService));
+ when(mountPoint.getService(DOMSchemaService.class)).thenReturn(Optional.of(SCHEMA_SERVICE));
final DOMMountPointService service = mock(DOMMountPointService.class);
when(service.getMountPoint(INSTANCE_ID)).thenReturn(Optional.of(mountPoint));
- final MountPointSwaggerGeneratorDraft02 generator =
- new MountPointSwaggerGeneratorDraft02(schemaService, service);
-
- swagger = generator.getMountPointSwagger();
+ swagger = new MountPointSwaggerGeneratorRFC8040(SCHEMA_SERVICE, service).getMountPointSwagger();
}
@Test()
final UriInfo mockInfo = DocGenTestHelper.createMockUriInfo(HTTP_URL);
swagger.onMountPointCreated(INSTANCE_ID); // add this ID into the list of mount points
- final SwaggerObject mountPointApi = (SwaggerObject) swagger.getMountPointApi(mockInfo, 1L, "Datastores",
- "-", URIType.DRAFT02, OAversion.V2_0);
+ final SwaggerObject mountPointApi = (SwaggerObject) swagger.getMountPointApi(mockInfo, 1L, "Datastores", "-",
+ OAversion.V2_0);
assertNotNull("failed to find Datastore API", mountPointApi);
final ObjectNode pathsObject = mountPointApi.getPaths();
assertNotNull(pathsObject);
- assertEquals("Unexpected api list size", 3, pathsObject.size());
+ assertEquals("Unexpected api list size", 2, pathsObject.size());
final Set<String> actualUrls = new TreeSet<>();
assertNotNull("expected non-null desc on " + path, getOperation.get("description"));
}
- final Set<String> expectedUrls = new TreeSet<>(Arrays.asList(
- "/restconf/config" + INSTANCE_URL + "yang-ext:mount",
- "/restconf/operational" + INSTANCE_URL + "yang-ext:mount",
- "/restconf/operations" + INSTANCE_URL + "yang-ext:mount"));
- assertEquals(expectedUrls, actualUrls);
+ assertEquals(Set.of("/rests/data" + INSTANCE_URL + "yang-ext:mount",
+ "/rests/operations" + INSTANCE_URL + "yang-ext:mount"), actualUrls);
}
}