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

Storing latest version to project data #408

Closed
wants to merge 1 commit into from
Closed
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 @@ -43,6 +43,7 @@
import org.finos.legend.depot.services.api.artifacts.handlers.ProjectArtifactsHandler;
import org.finos.legend.depot.core.services.tracing.TracerFactory;
import org.finos.legend.depot.core.services.metrics.PrometheusMetricsFactory;
import org.finos.legend.sdlc.domain.model.version.VersionId;
import org.slf4j.Logger;

import javax.inject.Inject;
Expand Down Expand Up @@ -242,6 +243,7 @@ MetadataEventResponse doRefresh(MetadataNotification event)
{

updateProjectVersionData(project, event.getVersionId(), newDependencies);
updateProjectData(project, event.getVersionId());
//we let the version load but will check dependencies exists and report missing dependencies as errors
if (!event.isTransitive())
{
Expand Down Expand Up @@ -304,6 +306,27 @@ private void updateProjectVersionData(StoreProjectData project, String versionId
LOGGER.info("Finished updating project data [{}-{}-{}]", project.getGroupId(), project.getArtifactId(), versionId);
}

private void updateProjectData(StoreProjectData projectData, String versionId)
{
if (!VersionValidator.isSnapshotVersion(versionId))
{
if (projectData.getLatestVersion() == null)
{
projectData.setLatestVersion(versionId);
projects.createOrUpdate(projectData);
}
else
{
//finding if the new version is the latest version
if (VersionId.parseVersionId(versionId).compareTo(VersionId.parseVersionId(projectData.getLatestVersion())) > 1)
{
projectData.setLatestVersion(versionId);
projects.createOrUpdate(projectData);
}
}
}
}

private String queueWorkToRefreshProjectVersion(StoreProjectData projectData, String versionId, boolean fullUpdate, boolean transitive, String parentEvent)
{
return String.format("queued: [%s-%s-%s], parentEventId :[%s], full/transitive :[%s/%s],event id :[%s] ",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ public void canEvictOldVersions()
List<String> projectVersions = projectsService.getVersions(TEST_GROUP_ID, TEST_ARTIFACT_ID);
Assert.assertEquals(3, projectVersions.size());
Assert.assertEquals("2.0.0", projectVersions.get(0));
Assert.assertEquals("2.3.0", projectsService.getLatestVersion(TEST_GROUP_ID, TEST_ARTIFACT_ID).get().toVersionIdString());
Assert.assertEquals("2.3.0", project.getLatestVersion());

Assert.assertEquals(2, entitiesStore.getAllEntities(TEST_GROUP_ID, TEST_ARTIFACT_ID, "2.0.0").size());
purgeService.evictOldestProjectVersions(TEST_GROUP_ID,TEST_ARTIFACT_ID,1);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,6 @@ public void setUpData()

projectsVersionsStore.createOrUpdate(new StoreProjectVersionData(TEST_GROUP_ID, TEST_DEPENDENCIES_ARTIFACT_ID, "2.0.0"));
projectsVersionsStore.createOrUpdate(new StoreProjectVersionData(TEST_GROUP_ID, TEST_DEPENDENCIES_ARTIFACT_ID, BRANCH_SNAPSHOT("master")));
projectsVersionsStore.createOrUpdate(new StoreProjectVersionData(TEST_GROUP_ID, TEST_ARTIFACT_ID,"2.3.3"));
projectsVersionsStore.createOrUpdate(new StoreProjectVersionData(TEST_GROUP_ID, TEST_ARTIFACT_ID, "1.0.0"));
projectsVersionsStore.createOrUpdate(new StoreProjectVersionData(TEST_GROUP_ID, TEST_ARTIFACT_ID, BRANCH_SNAPSHOT("master")));

Expand Down Expand Up @@ -202,8 +201,6 @@ public void canUpdateCreateMasterRevision()
@Test
public void canRefreshProjectVersion()
{
Assert.assertEquals(0, entitiesStore.getAllEntities(TEST_GROUP_ID, TEST_ARTIFACT_ID, "2.3.3").size());

Assert.assertEquals(0, entitiesStore.getAllEntities(TEST_GROUP_ID, TEST_DEPENDENCIES_ARTIFACT_ID, "1.0.0").size());

MetadataEventResponse response = artifactsRefreshService.refreshVersionForProject(TEST_GROUP_ID, TEST_ARTIFACT_ID, "2.0.0",true,PARENT_EVENT_ID);
Expand Down Expand Up @@ -344,15 +341,15 @@ public void partialRefreshAllVersionForProjectOnlyRefreshLatest()
notificationsQueueManager.handleAll();

List<String> versions = projectsService.getVersions(TEST_GROUP_ID, TEST_ARTIFACT_ID);
Assert.assertEquals(3, versions.size());
Assert.assertEquals("2.3.3",projectsService.getLatestVersion(TEST_GROUP_ID, TEST_ARTIFACT_ID).get().toVersionIdString());
Assert.assertEquals(2, versions.size());
Assert.assertEquals("2.0.0",projectsService.findCoordinates(TEST_GROUP_ID, TEST_ARTIFACT_ID).get().getLatestVersion());


projectsService.delete(TEST_GROUP_ID, TEST_ARTIFACT_ID, "1.0.0");
Assert.assertEquals("2.3.3",projectsService.getLatestVersion(TEST_GROUP_ID,TEST_ARTIFACT_ID).get().toVersionIdString());
Assert.assertEquals("2.0.0",projectsService.findCoordinates(TEST_GROUP_ID,TEST_ARTIFACT_ID).get().getLatestVersion());

artifactsRefreshService.refreshAllVersionsForProject(TEST_GROUP_ID, TEST_ARTIFACT_ID, false, false, false,PARENT_EVENT_ID);
Assert.assertEquals("2.3.3",projectsService.getLatestVersion(TEST_GROUP_ID,TEST_ARTIFACT_ID).get().toVersionIdString());
Assert.assertEquals("2.0.0",projectsService.findCoordinates(TEST_GROUP_ID,TEST_ARTIFACT_ID).get().getLatestVersion());
Assert.assertEquals(2,notificationsQueueManager.getAllInQueue().size());
Assert.assertEquals("1.0.0",notificationsQueueManager.getAllInQueue().get(1).getVersionId());
notificationsQueueManager.handleAll();
Expand Down Expand Up @@ -502,7 +499,7 @@ public void cantRefreshSameVersionTwice()
notificationsQueueManager.handleAll();
Assert.assertEquals(docsBefore,entitiesStore.getAllStoredEntities().size());
Assert.assertTrue(projectsVersionsStore.find(TEST_GROUP_ID,TEST_ARTIFACT_ID,versionId).isPresent());
Assert.assertEquals(3,projectsVersionsStore.find(TEST_GROUP_ID,TEST_ARTIFACT_ID).stream().filter(x -> !x.getVersionId().equals(BRANCH_SNAPSHOT("master"))).collect(Collectors.toList()).size());
Assert.assertEquals(2,projectsVersionsStore.find(TEST_GROUP_ID,TEST_ARTIFACT_ID).stream().filter(x -> !x.getVersionId().equals(BRANCH_SNAPSHOT("master"))).collect(Collectors.toList()).size());
Assert.assertEquals(0,notificationsQueueManager.getAllInQueue().size());
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,14 @@
{
"projectId": "PROD-A",
"groupId": "examples.metadata",
"artifactId": "test"
"artifactId": "test",
"latestVersion": "2.3.0"
},
{
"projectId": "PROD-B",
"groupId": "examples.metadata",
"artifactId": "test-dependencies"
"artifactId": "test-dependencies",
"latestVersion": "1.0.0"
},
{
"projectId": "PROD-C",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,20 +31,13 @@ public interface ProjectsService
{
List<StoreProjectData> getAllProjectCoordinates();

/**
* NOTE: page starting from 1
*/
List<StoreProjectData> getProjects(int page, int pageSize);

default List<String> getVersions(String groupId, String artifactId)
{
return getVersions(groupId, artifactId,false);
}

List<String> getVersions(String groupId, String artifactId,boolean includeSnapshots);

Optional<VersionId> getLatestVersion(String groupId, String artifactId);

@Deprecated
List<StoreProjectData> findByProjectId(String projectId);

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -24,11 +24,6 @@ public interface Projects
{
List<StoreProjectData> getAll();

/**
* NOTE: page starting from 1
*/
List<StoreProjectData> getProjects(int page, int pageSize);

Optional<StoreProjectData> find(String groupId, String artifactId);

@Deprecated
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -32,15 +32,19 @@ public class StoreProjectData extends CoordinateData implements HasIdentifier
@JsonProperty
private String projectId;

@JsonProperty
private String latestVersion;

public StoreProjectData()
{
super();
}

public StoreProjectData(String projectId, String groupId, String artifactId, String defaultBranch)
public StoreProjectData(String projectId, String groupId, String artifactId, String defaultBranch, String latestVersion)
{
this(projectId, groupId, artifactId);
this.defaultBranch = defaultBranch;
this.latestVersion = latestVersion;
}

public StoreProjectData(String projectId,String groupId,String artifactId)
Expand All @@ -64,6 +68,16 @@ public String getProjectId()
return projectId;
}

public String getLatestVersion()
{
return latestVersion;
}

public void setLatestVersion(String latestVersion)
{
this.latestVersion = latestVersion;
}

@Override
@JsonIgnore
public String getId()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,6 @@
import org.finos.legend.depot.store.api.projects.UpdateProjects;
import org.finos.legend.depot.services.api.metrics.query.QueryMetricsRegistry;
import org.finos.legend.depot.store.notifications.queue.api.Queue;
import org.finos.legend.sdlc.domain.model.version.VersionId;

import javax.inject.Inject;
import javax.inject.Named;
Expand Down Expand Up @@ -101,12 +100,6 @@ public List<StoreProjectData> getAllProjectCoordinates()
return projects.getAll();
}

@Override
public List<StoreProjectData> getProjects(int page, int pageSize)
{
return projects.getProjects(page, pageSize);
}

@Override
public List<String> getVersions(String groupId, String artifactId,boolean includeSnapshots)
{
Expand Down Expand Up @@ -154,7 +147,12 @@ public Optional<StoreProjectVersionData> find(String groupId, String artifactId,
{
if (VersionAlias.LATEST.getName().equals(versionId))
{
return projectsVersions.find(groupId, artifactId).stream().filter(v -> !VersionValidator.isSnapshotVersion(v.getVersionId()) && !v.getVersionData().isExcluded()).max(Comparator.comparing(o -> VersionId.parseVersionId(o.getVersionId())));
Optional<StoreProjectData> projectData = this.findCoordinates(groupId, artifactId);
if (projectData.isPresent())
{
return projectsVersions.find(groupId, artifactId, projectData.get().getLatestVersion());
}
return Optional.empty();
}
else if (VersionAlias.HEAD.getName().equals(versionId))
{
Expand Down Expand Up @@ -213,12 +211,6 @@ public void checkExists(String groupId, String artifactId) throws IllegalArgumen
}
}

@Override
public Optional<VersionId> getLatestVersion(String groupId, String artifactId)
{
return this.getVersions(groupId, artifactId,false).stream().map(v -> VersionId.parseVersionId(v)).max(VersionId::compareTo);
}

@Override
public Set<ProjectVersion> getDependencies(List<ProjectVersion> projectVersions, boolean transitive)
{
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -62,15 +62,15 @@ protected String getResourceName()
@Path("/projects/{projectId}/{groupId}/{artifactId}")
@ApiOperation(ResourceLoggingAndTracing.CREATE_UPDATE_PROJECT)
@Produces(MediaType.APPLICATION_JSON)
public StoreProjectData updateProject(@PathParam("projectId") String projectId, @PathParam("groupId") String groupId, @PathParam("artifactId") String artifactId, @QueryParam("defaultBranch") @ApiParam String defaultBranch)
public StoreProjectData updateProject(@PathParam("projectId") String projectId, @PathParam("groupId") String groupId, @PathParam("artifactId") String artifactId, @QueryParam("defaultBranch") @ApiParam String defaultBranch, @QueryParam("latestVersion") @ApiParam String latestVersion)
{
return handle(
ResourceLoggingAndTracing.CREATE_UPDATE_PROJECT,
ResourceLoggingAndTracing.CREATE_UPDATE_PROJECT + projectId,
() ->
{
validateUser();
return projectApi.createOrUpdate(new StoreProjectData(projectId, groupId, artifactId, defaultBranch));
return projectApi.createOrUpdate(new StoreProjectData(projectId, groupId, artifactId, defaultBranch, latestVersion));
});
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -281,7 +281,7 @@ public void canGetProjectCoordinatesByGA()
{
Optional<StoreProjectData> storeProjectData = projectsService.findCoordinates("examples.metadata", "test");
Assert.assertTrue(storeProjectData.isPresent());
Assert.assertEquals(storeProjectData.get(), new StoreProjectData("PROD-A", "examples.metadata", "test"));
Assert.assertEquals(storeProjectData.get(), new StoreProjectData("PROD-A", "examples.metadata", "test", null, "2.3.1"));

Optional<StoreProjectData> storeProjectData1 = projectsService.findCoordinates("dummy.dep", "test");
Assert.assertFalse(storeProjectData1.isPresent());
Expand Down Expand Up @@ -352,11 +352,11 @@ public void canGetLatestVersionForProject()
Assert.assertNotNull(fullVersions);
Assert.assertEquals(2, fullVersions.size());

Assert.assertTrue(projectsService.getLatestVersion("examples.metadata", "test").isPresent());
Assert.assertEquals("2.3.1", projectsService.getLatestVersion("examples.metadata", "test").get().toVersionIdString());
Assert.assertTrue(projectsService.findCoordinates("examples.metadata", "test").isPresent());
Assert.assertEquals("2.3.1", projectsService.findCoordinates("examples.metadata", "test").get().getLatestVersion());

Assert.assertTrue(projectsService.find("examples.metadata", "test","latest").isPresent());
Assert.assertEquals("2.3.1", projectsService.getLatestVersion("examples.metadata", "test").get().toVersionIdString());
Assert.assertEquals("2.3.1", projectsService.findCoordinates("examples.metadata", "test").get().getLatestVersion());

Assert.assertFalse(projectsService.find("dont","exist","latest").isPresent());

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -55,5 +55,11 @@ public void addTransitiveDependenciesToVersionData()
{
new DependenciesMigration(mongoDatabase).addTransitiveDependenciesToVersionData();
}

@Deprecated
public void addLatestVersionToProjectData()
{
new ProjectToProjectVersionMigration(mongoDatabase).addLatestVersionToProjectData();
}
}

Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@

package org.finos.legend.depot.store.mongo.admin.migrations;

import com.mongodb.client.FindIterable;
import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoDatabase;
import com.mongodb.client.model.Filters;
Expand All @@ -27,12 +28,17 @@
import org.finos.legend.depot.store.mongo.core.BaseMongo;
import org.finos.legend.depot.store.mongo.projects.ProjectsMongo;
import org.finos.legend.depot.store.mongo.projects.ProjectsVersionsMongo;
import org.finos.legend.sdlc.domain.model.version.VersionId;
import org.slf4j.Logger;

import java.util.Collections;
import java.util.List;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.Optional;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.stream.Collectors;

import static org.finos.legend.depot.domain.version.VersionValidator.BRANCH_SNAPSHOT;
Expand All @@ -42,6 +48,7 @@ public final class ProjectToProjectVersionMigration
{
private static final Logger LOGGER = org.slf4j.LoggerFactory.getLogger(ProjectToProjectVersionMigration.class);
private final MongoDatabase mongoDatabase;
private static final String EXCLUDED = "versionData.excluded";

public ProjectToProjectVersionMigration(MongoDatabase mongoDatabase)
{
Expand Down Expand Up @@ -128,4 +135,43 @@ public void cleanUpProjectData()
});
LOGGER.info(String.format("versions updated [%s]", i.get()));
}

@Deprecated
public void addLatestVersionToProjectData()
{
MongoCollection<Document> projectCollection = mongoDatabase.getCollection(ProjectsMongo.COLLECTION);
MongoCollection<Document> versionCollection = mongoDatabase.getCollection(ProjectsVersionsMongo.COLLECTION);
projectCollection.find().forEach((Consumer<Document>) document ->
{
AtomicInteger i = new AtomicInteger();
String groupId = document.getString(BaseMongo.GROUP_ID);
String artifactId = document.getString(BaseMongo.ARTIFACT_ID);
try
{
FindIterable<Document> versionDocument = versionCollection.find(Filters.and(
Filters.eq(BaseMongo.GROUP_ID, groupId), Filters.eq(BaseMongo.ARTIFACT_ID, artifactId),
Filters.not(Filters.regex(BaseMongo.VERSION_ID, BRANCH_SNAPSHOT(""))), Filters.eq(EXCLUDED, false)));
List<VersionId> parsedVersions = new ArrayList<>();
versionDocument.forEach((Consumer<Document>) doc ->
{
parsedVersions.add(VersionId.parseVersionId(doc.getString(BaseMongo.VERSION_ID)));
});
Optional<VersionId> latestVersion = parsedVersions.stream().max(Comparator.comparing(Function.identity()));
if (latestVersion.isPresent())
{
LOGGER.info(String.format("%s-%s updated with latest version", groupId, artifactId));
projectCollection.updateOne(Filters.and(Filters.eq(BaseMongo.GROUP_ID, groupId),
Filters.eq(BaseMongo.ARTIFACT_ID, artifactId)), Updates.set("latestVersion", latestVersion.get().toVersionIdString()));
LOGGER.info(String.format("%s-%s update completed",groupId,artifactId));
}
LOGGER.info(String.format("projects updated [%s]",i.incrementAndGet()));
}
catch (Exception e)
{
LOGGER.info("Error while updating data:" + e.getMessage());
LOGGER.info(String.format("projects updated [%s] before error",i.get()));
LOGGER.info(String.format("%s-%s update could not be completed",groupId, artifactId));
}
});
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -35,7 +35,6 @@
import java.util.List;
import java.util.Optional;


public class ProjectsMongo extends BaseMongo<StoreProjectData> implements Projects, UpdateProjects
{

Expand Down Expand Up @@ -87,12 +86,6 @@ public List<StoreProjectData> getAll()
return getAllStoredEntities();
}

@Override
public List<StoreProjectData> getProjects(int page, int pageSize)
{
return getStoredEntitiesByPage(page, pageSize);
}

@Override
public List<StoreProjectData> findByProjectId(String projectId)
{
Expand Down
Loading
Loading