Skip to content

Commit

Permalink
fix(aspects): fix default aspect generation for non-restli locations
Browse files Browse the repository at this point in the history
  • Loading branch information
david-leifker committed Jan 30, 2024
1 parent f378fb6 commit 5898845
Show file tree
Hide file tree
Showing 39 changed files with 519 additions and 524 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
import com.linkedin.datahub.upgrade.UpgradeStepResult;
import com.linkedin.datahub.upgrade.impl.DefaultUpgradeStepResult;
import com.linkedin.metadata.Constants;
import com.linkedin.metadata.aspect.utils.DefaultAspectsUtil;
import com.linkedin.metadata.entity.EntityService;
import com.linkedin.metadata.entity.ebean.EbeanAspectV1;
import com.linkedin.metadata.entity.ebean.EbeanAspectV2;
Expand Down Expand Up @@ -170,7 +171,7 @@ public Function<UpgradeContext, UpgradeStepResult> executable() {
// Emit a browse path aspect.
final BrowsePaths browsePaths;
try {
browsePaths = _entityService.buildDefaultBrowsePath(urn);
browsePaths = DefaultAspectsUtil.buildDefaultBrowsePath(urn, _entityService);

final AuditStamp browsePathsStamp = new AuditStamp();
browsePathsStamp.setActor(Urn.createFromString(Constants.SYSTEM_ACTOR));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@
import com.linkedin.datahub.upgrade.impl.DefaultUpgradeStepResult;
import com.linkedin.events.metadata.ChangeType;
import com.linkedin.metadata.Constants;
import com.linkedin.metadata.aspect.utils.DefaultAspectsUtil;
import com.linkedin.metadata.entity.EntityService;
import com.linkedin.metadata.query.SearchFlags;
import com.linkedin.metadata.query.filter.Condition;
Expand Down Expand Up @@ -181,7 +182,8 @@ private Filter backfillDefaultBrowsePathsV2Filter() {
}

private void ingestBrowsePathsV2(Urn urn, AuditStamp auditStamp) throws Exception {
BrowsePathsV2 browsePathsV2 = _entityService.buildDefaultBrowsePathV2(urn, true);
BrowsePathsV2 browsePathsV2 =
DefaultAspectsUtil.buildDefaultBrowsePathV2(urn, true, _entityService);
log.debug(String.format("Adding browse path v2 for urn %s with value %s", urn, browsePathsV2));
MetadataChangeProposal proposal = new MetadataChangeProposal();
proposal.setEntityUrn(urn);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
import com.linkedin.metadata.aspect.plugins.validation.AspectRetriever;
import com.linkedin.mxe.SystemMetadata;
import com.linkedin.util.Pair;
import java.util.Collection;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
Expand All @@ -17,14 +18,14 @@
* SystemMetadata} and record/message created time
*/
public interface AspectsBatch {
List<? extends BatchItem> getItems();
Collection<? extends BatchItem> getItems();

/**
* Returns MCP items. Can be patch, upsert, etc.
*
* @return batch items
*/
default List<? extends MCPBatchItem> getMCPItems() {
default Collection<? extends MCPBatchItem> getMCPItems() {
return getItems().stream()
.filter(item -> item instanceof MCPBatchItem)
.map(item -> (MCPBatchItem) item)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,11 +2,13 @@

import com.linkedin.common.AuditStamp;
import com.linkedin.common.urn.Urn;
import com.linkedin.data.template.RecordTemplate;
import com.linkedin.events.metadata.ChangeType;
import com.linkedin.metadata.models.AspectSpec;
import com.linkedin.metadata.models.EntitySpec;
import com.linkedin.mxe.SystemMetadata;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;

public interface BatchItem {
/**
Expand Down Expand Up @@ -63,4 +65,12 @@ default String getAspectName() {
*/
@Nonnull
AspectSpec getAspectSpec();

/**
* The aspect's record template. Null when patch
*
* @return record template if it exists
*/
@Nullable
RecordTemplate getRecordTemplate();
}
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@ default String getAspectName() {
if (getMetadataChangeLog().getAspectName() != null) {
return getMetadataChangeLog().getAspectName();
} else {
return getAspect().schema().getName();
return getRecordTemplate().schema().getName();
}
}

Expand All @@ -40,10 +40,7 @@ default SystemMetadata getPreviousSystemMetadata() {
}

@Nullable
RecordTemplate getPreviousAspect();

@Nonnull
RecordTemplate getAspect();
RecordTemplate getPreviousRecordTemplate();

@Override
@Nonnull
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,6 @@
* related data stored along with the aspect
*/
public abstract class UpsertItem extends MCPBatchItem {
public abstract RecordTemplate getAspect();

public abstract SystemAspect toLatestEntityAspect();

public abstract void validatePreCommit(
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
<?xml version="1.0" encoding="utf-8"?><testsuites><testsuite name="pytest" errors="0" failures="0" skipped="0" tests="11" time="0.333" timestamp="2023-12-13T12:13:15.867560" hostname="Davids-MacBook-Pro-2.local"><testcase classname="spark-smoke-test.test_e2e" name="test_healthchecks" time="0.000" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[JavaHdfsIn2HdfsOut1.json]" time="0.043" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[PythonHdfsIn2HiveCreateInsertTable.json]" time="0.027" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[JavaHdfsIn2HiveCreateInsertTable.json]" time="0.022" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[PythonHiveInHiveOut.json]" time="0.032" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[PythonHdfsIn2HdfsOut2.json]" time="0.021" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[PythonHdfsIn2HdfsOut1.json]" time="0.010" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[JavaHdfsIn2HiveCreateTable.json]" time="0.012" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[JavaHiveInHiveOut.json]" time="0.025" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[JavaHdfsIn2HdfsOut2.json]" time="0.015" /><testcase classname="spark-smoke-test.test_e2e" name="test_ingestion_via_rest[PythonHdfsIn2HiveCreateTable.json]" time="0.010" /></testsuite></testsuites>
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,9 @@ public static void resetBaseExpectations() {

@BeforeClass
public static void initMockServer() {
mockServer = startClientAndServer(GMS_PORT);
if (mockServer == null) {
mockServer = startClientAndServer(GMS_PORT);
}
resetBaseExpectations();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -138,7 +138,9 @@ public static void resetBaseExpectations() {

@BeforeClass
public static void init() {
mockServer = startClientAndServer(GMS_PORT);
if (mockServer == null) {
mockServer = startClientAndServer(GMS_PORT);
}
resetBaseExpectations();
}

Expand Down
Loading

0 comments on commit 5898845

Please sign in to comment.