Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

1456 - created new entity DataSourceSafe without token which used in … #1466

Merged
merged 1 commit into from
Oct 13, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,7 @@ public class DataEntityMapperImpl implements DataEntityMapper {
private static DataEntityClassAndTypeDictionary TYPE_DICTIONARY = null;

private final DataSourceMapper dataSourceMapper;
private final DataSourceSafeMapper dataSourceSafeMapper;
private final OwnershipMapper ownershipMapper;
private final TagMapper tagMapper;
private final MetadataFieldValueMapper metadataFieldValueMapper;
Expand All @@ -86,7 +87,7 @@ public DataEntity mapPojo(final DataEntityDimensionsDto dto) {
.entityClasses(entityClasses.stream().map(this::mapEntityClass).toList())
.type(type)
.ownership(ownershipMapper.mapDtos(dto.getOwnership()))
.dataSource(dataSourceMapper.mapDto(new DataSourceDto(dto.getDataSource(), dto.getNamespace(), null)))
.dataSource(dataSourceSafeMapper.mapDto(new DataSourceDto(dto.getDataSource(), dto.getNamespace(), null)))
.dataEntityGroups(groups);

if (entityClasses.contains(DataEntityClassDto.DATA_SET)) {
Expand Down Expand Up @@ -250,7 +251,7 @@ public DataEntityDetails mapDtoDetails(final DataEntityDetailsDto dto) {
.type(type)
.status(dataEntityStatusMapper.mapStatus(pojo))
.ownership(ownershipMapper.mapDtos(dto.getOwnership()))
.dataSource(dataSourceMapper.mapDto(new DataSourceDto(dto.getDataSource(), dto.getNamespace(), null)))
.dataSource(dataSourceSafeMapper.mapDto(new DataSourceDto(dto.getDataSource(), dto.getNamespace(), null)))
.tags(tagMapper.mapToTagList(dto.getTags()))
.metadataFieldValues(metadataFieldValueMapper.mapDtos(dto.getMetadata()))
.terms(linkedTerms)
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package org.opendatadiscovery.oddplatform.mapper;

import org.mapstruct.Mapper;
import org.mapstruct.Mapping;
import org.opendatadiscovery.oddplatform.api.contract.model.DataSourceSafe;
import org.opendatadiscovery.oddplatform.dto.DataSourceDto;

@Mapper(
config = MapperConfig.class,
uses = {NamespaceMapper.class}
)
public interface DataSourceSafeMapper {
@Mapping(source = "dataSource", target = ".")
DataSourceSafe mapDto(DataSourceDto dataSourceDto);
}
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
import org.opendatadiscovery.oddplatform.api.contract.model.DataSetStructure;
import org.opendatadiscovery.oddplatform.api.contract.model.DataSource;
import org.opendatadiscovery.oddplatform.api.contract.model.DataSourceFormData;
import org.opendatadiscovery.oddplatform.api.contract.model.DataSourceSafe;
import org.opendatadiscovery.oddplatform.api.contract.model.MetricSet;
import org.opendatadiscovery.oddplatform.api.contract.model.SearchFacetsData;
import org.opendatadiscovery.oddplatform.api.contract.model.SearchFilterState;
Expand Down Expand Up @@ -53,6 +54,12 @@ protected DataSource createDataSource(final DataSourceFormData dataSource) {
return ingestDataSource(dataSource);
}

protected DataSourceSafe createDataSourceSafeFromDataSource(final DataSource dataSource) {
return new DataSourceSafe(dataSource.getId(), dataSource.getOddrn(), dataSource.getName())
.description(dataSource.getDescription())
.namespace(dataSource.getNamespace());
}

private DataSource ingestDataSource(final DataSourceFormData dataSource) {
return webTestClient.post()
.uri("/api/datasources")
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,8 @@ public void backwardsIncompatibleAlertIngestionTest() {
final long foundEntityId = extractIngestedEntityIdAndAssert(createdDataSource);

final var expectedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand All @@ -98,7 +99,8 @@ public void backwardsIncompatibleAlertIngestionTest() {
ingestAndAssert(dataEntityList);

final var updatedExpectedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand Down Expand Up @@ -152,7 +154,8 @@ public void failedJobAlertIngestionTest() {
final long jobId = extractIngestedEntityIdAndAssert(createdDataSource);

final DataEntityDetails expectedDataEntityDetails =
IngestionModelMapper.buildExpectedBaseDEDetails(jobId, job, createdDataSource);
IngestionModelMapper.buildExpectedBaseDEDetails(jobId, job,
createDataSourceSafeFromDataSource(createdDataSource));

assertDataEntityDetailsEqual(expectedDataEntityDetails, (expected, actual) -> {
assertThat(actual.getSourceList()).isEmpty();
Expand Down Expand Up @@ -218,7 +221,8 @@ public void failedDQTestAlertIngestionTest() {
.forEach((expectedOddrn, dataEntity) -> {
final long entityId = ingestionMap.get(expectedOddrn);
final DataEntityDetails expectedDetails =
IngestionModelMapper.buildExpectedBaseDEDetails(entityId, dataEntity, createdDataSource);
IngestionModelMapper.buildExpectedBaseDEDetails(entityId, dataEntity,
createDataSourceSafeFromDataSource(createdDataSource));

if (dataEntity.getDataset() != null) {
expectedDetails.setStats(new DataSetStats()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -69,7 +69,8 @@ public void enumValuesComplexTest() {
final long foundEntityId = extractIngestedEntityIdAndAssert(createdDataSource);

final var expectedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand Down Expand Up @@ -155,7 +156,8 @@ public void rewritingInternalEnumStateTest() {
final long foundEntityId = extractIngestedEntityIdAndAssert(createdDataSource);

final var expectedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand Down Expand Up @@ -222,7 +224,8 @@ public void externalStatisticsTagStateIngestionTest() {
final long foundEntityId = extractIngestedEntityIdAndAssert(createdDataSource);

final var expectedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,8 @@ public void simpleDatasetIngestionTest() {
final long foundEntityId = extractIngestedEntityIdAndAssert(createdDataSource);

final var expectedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand Down Expand Up @@ -107,7 +108,8 @@ public void changeDatasetStructureTest() {
final long foundEntityId = extractIngestedEntityIdAndAssert(createdDataSource);

final var expectedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand Down Expand Up @@ -142,7 +144,8 @@ public void changeDatasetStructureTest() {
ingestAndAssert(dataEntityList);

final var updatedExpectedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand Down Expand Up @@ -213,7 +216,8 @@ public void updateHollowDatasetSchemaTest() {
assertThat(dataEntityId).isNotNull();

final DataEntityDetails expectedDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(dataEntityId, dataEntity, createdDataSource);
.buildExpectedBaseDEDetails(dataEntityId, dataEntity,
createDataSourceSafeFromDataSource(createdDataSource));

if (dataEntity.getDataset() != null) {
expectedDetails.setStats(new DataSetStats()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,8 @@ public void simpleLineageIngestionTest() {
assertThat(dataEntityId).isNotNull();

final DataEntityDetails expectedDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(dataEntityId, dataEntity, createdDataSource);
.buildExpectedBaseDEDetails(dataEntityId, dataEntity,
createDataSourceSafeFromDataSource(createdDataSource));

if (dataEntity.getDataset() != null) {
expectedDetails.setStats(new DataSetStats()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,8 @@ public void simpleMetadataIngestionTest() {
final long foundEntityId = extractIngestedEntityIdAndAssert(createdDataSource);

final var expectedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand Down Expand Up @@ -78,7 +79,8 @@ public void simpleMetadataIngestionTest() {
ingestAndAssert(dataEntityList);

final var expectedUpdatedDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand All @@ -95,7 +97,8 @@ public void simpleMetadataIngestionTest() {
ingestAndAssert(dataEntityList);

final var expectedEmptyMetadataDataEntityDetails = IngestionModelMapper
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest, createdDataSource)
.buildExpectedBaseDEDetails(foundEntityId, datasetToIngest,
createDataSourceSafeFromDataSource(createdDataSource))
.stats(new DataSetStats()
.consumersCount(0L)
.fieldsCount((long) datasetToIngest.getDataset().getFieldList().size())
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@
import org.opendatadiscovery.oddplatform.api.contract.model.DataSetField;
import org.opendatadiscovery.oddplatform.api.contract.model.DataSetFieldStat;
import org.opendatadiscovery.oddplatform.api.contract.model.DataSetFieldType;
import org.opendatadiscovery.oddplatform.api.contract.model.DataSource;
import org.opendatadiscovery.oddplatform.api.contract.model.DataSourceSafe;
import org.opendatadiscovery.oddplatform.api.contract.model.DateTimeFieldStat;
import org.opendatadiscovery.oddplatform.api.contract.model.EnumValue;
import org.opendatadiscovery.oddplatform.api.contract.model.IntegerFieldStat;
Expand All @@ -33,7 +33,7 @@
public class IngestionModelMapper {
public static DataEntityDetails buildExpectedBaseDEDetails(final long entityId,
final DataEntity dataEntity,
final DataSource dataSource) {
final DataSourceSafe dataSource) {
return new DataEntityDetails()
.id(entityId)
.sourceCreatedAt(dataEntity.getCreatedAt())
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,9 @@ void setUp() {
new DateTimeMapperImpl()
)
),
new DataSourceSafeMapperImpl(
new NamespaceMapperImpl()
),
new OwnershipMapperImpl(
new OwnerMapperImpl(),
new TitleMapperImpl()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
import org.opendatadiscovery.oddplatform.mapper.DataEntityRunMapperImpl;
import org.opendatadiscovery.oddplatform.mapper.DataEntityStatusMapper;
import org.opendatadiscovery.oddplatform.mapper.DataSourceMapperImpl;
import org.opendatadiscovery.oddplatform.mapper.DataSourceSafeMapperImpl;
import org.opendatadiscovery.oddplatform.mapper.DatasetFieldApiMapperImpl;
import org.opendatadiscovery.oddplatform.mapper.DatasetVersionMapperImpl;
import org.opendatadiscovery.oddplatform.mapper.DateTimeMapperImpl;
Expand Down Expand Up @@ -81,6 +82,9 @@ void setUp() {
new DateTimeMapperImpl()
)
),
new DataSourceSafeMapperImpl(
new NamespaceMapperImpl()
),
new OwnershipMapperImpl(
new OwnerMapperImpl(),
new TitleMapperImpl()
Expand Down
23 changes: 20 additions & 3 deletions odd-platform-specification/components.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -530,7 +530,7 @@ components:
ownership:
$ref: '#/components/schemas/OwnershipList'
data_source:
$ref: '#/components/schemas/DataSource'
$ref: '#/components/schemas/DataSourceSafe'
entity_classes:
type: array
items:
Expand Down Expand Up @@ -1210,6 +1210,25 @@ components:
- oddrn
- name

DataSourceSafe:
type: object
properties:
id:
type: integer
format: int64
namespace:
$ref: '#/components/schemas/Namespace'
oddrn:
type: string
name:
type: string
description:
type: string
required:
- id
- oddrn
- name

DataSourceList:
type: object
properties:
Expand Down Expand Up @@ -1462,8 +1481,6 @@ components:
$ref: '#/components/schemas/BinaryFieldStat'
datetime_stats:
$ref: '#/components/schemas/DateTimeFieldStat'
required:
- name

BooleanFieldStat:
type: object
Expand Down