src/main/java/com/microfocus/application/automation/tools/octane/model/processors/scm/SvnSCMProcessor.java
/*
* Certain versions of software accessible here may contain branding from Hewlett-Packard Company (now HP Inc.) and Hewlett Packard Enterprise Company.
* This software was acquired by Micro Focus on September 1, 2017, and is now offered by OpenText.
* Any reference to the HP and Hewlett Packard Enterprise/HPE marks is historical in nature, and the HP and Hewlett Packard Enterprise/HPE marks are the property of their respective owners.
* __________________________________________________________________
* MIT License
*
* Copyright 2012-2024 Open Text
*
* The only warranties for products and services of Open Text and
* its affiliates and licensors ("Open Text") are as may be set forth
* in the express warranty statements accompanying such products and services.
* Nothing herein should be construed as constituting an additional warranty.
* Open Text shall not be liable for technical or editorial errors or
* omissions contained herein. The information contained herein is subject
* to change without notice.
*
* Except as specifically indicated otherwise, this document contains
* confidential information and a valid license is required for possession,
* use or copying. If this work is provided to the U.S. Government,
* consistent with FAR 12.211 and 12.212, Commercial Computer Software,
* Computer Software Documentation, and Technical Data for Commercial Items are
* licensed to the U.S. Government under vendor's standard commercial license.
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* ___________________________________________________________________
*/
package com.microfocus.application.automation.tools.octane.model.processors.scm;
import com.hp.octane.integrations.dto.DTOFactory;
import com.hp.octane.integrations.dto.scm.SCMChange;
import com.hp.octane.integrations.dto.scm.SCMCommit;
import com.hp.octane.integrations.dto.scm.SCMData;
import com.hp.octane.integrations.dto.scm.SCMRepository;
import com.hp.octane.integrations.dto.scm.SCMType;
import com.microfocus.application.automation.tools.octane.configuration.SDKBasedLoggerProvider;
import hudson.model.*;
import hudson.scm.ChangeLogSet;
import hudson.scm.SCM;
import hudson.scm.SVNRevisionState;
import hudson.scm.SubversionChangeLogSet;
import hudson.scm.SubversionSCM;
import hudson.tasks.Mailer;
import org.apache.logging.log4j.Logger;
import org.jenkinsci.plugins.workflow.job.WorkflowRun;
import java.io.IOException;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
/**
* Created by benmeior on 5/15/2016.
*/
class SvnSCMProcessor implements SCMProcessor {
private static final Logger logger = SDKBasedLoggerProvider.getLogger(SvnSCMProcessor.class);
private static final DTOFactory dtoFactory = DTOFactory.getInstance();
private static final int PARENT_COMMIT_INDEX = 1;
@Override
public SCMData getSCMData(AbstractBuild build, SCM scm) {
List<ChangeLogSet<? extends ChangeLogSet.Entry>> changes = new ArrayList<>();
changes.add(build.getChangeSet());
return extractSCMData(build, scm, changes);
}
@Override
public SCMData getSCMData(WorkflowRun run, SCM scm) {
return extractSCMData(run, scm, run.getChangeSets());
}
@Override
public CommonOriginRevision getCommonOriginRevision(Run run) {
return null;
}
private SCMData extractSCMData(Run run, SCM scm, List<ChangeLogSet<? extends ChangeLogSet.Entry>> changes) {
if (!(scm instanceof SubversionSCM)) {
throw new IllegalArgumentException("SubversionSCM type of SCM was expected here, found '" + scm.getClass().getName() + "'");
}
SubversionSCM svnData = (SubversionSCM) scm;
SCMRepository repository;
List<SCMCommit> tmpCommits;
String builtRevId;
repository = getSCMRepository(svnData);
builtRevId = getBuiltRevId(run, svnData, repository.getUrl());
tmpCommits = extractCommits(changes);
return dtoFactory.newDTO(SCMData.class)
.setRepository(repository)
.setBuiltRevId(builtRevId)
.setCommits(tmpCommits);
}
private List<SCMCommit> extractCommits(List<ChangeLogSet<? extends ChangeLogSet.Entry>> changes) {
List<SCMCommit> tmpCommits;
List<SCMChange> tmpChanges;
SCMChange tmpChange;
tmpCommits = new LinkedList<>();
for (ChangeLogSet<? extends ChangeLogSet.Entry> set : changes) {
for (ChangeLogSet.Entry change : set) {
if (change instanceof SubversionChangeLogSet.LogEntry) {
SubversionChangeLogSet.LogEntry commit = (SubversionChangeLogSet.LogEntry) change;
User user = commit.getAuthor();
String userEmail = null;
tmpChanges = new ArrayList<>();
for (SubversionChangeLogSet.Path item : commit.getAffectedFiles()) {
tmpChange = dtoFactory.newDTO(SCMChange.class)
.setType(item.getEditType().getName())
.setFile(item.getValue());
tmpChanges.add(tmpChange);
}
for (UserProperty property : user.getAllProperties()) {
if (property instanceof Mailer.UserProperty) {
userEmail = ((Mailer.UserProperty) property).getAddress();
}
}
String parentRevId = getParentRevId(commit);
SCMCommit tmpCommit = dtoFactory.newDTO(SCMCommit.class)
.setTime(commit.getTimestamp())
.setUser(commit.getAuthor().getId())
.setUserEmail(userEmail)
.setRevId(commit.getCommitId())
.setParentRevId(parentRevId)
.setComment(commit.getMsg().trim())
.setChanges(tmpChanges);
tmpCommits.add(tmpCommit);
}
}
}
return tmpCommits;
}
private String getBuiltRevId(Run run, SubversionSCM svnData, String svnRepositoryUrl) {
String builtRevId = null;
try {
SVNRevisionState revisionState = (SVNRevisionState) svnData.calcRevisionsFromBuild(run, null, null, null);
if (revisionState != null) {
builtRevId = String.valueOf(revisionState.getRevision(svnRepositoryUrl));
}
} catch (IOException | InterruptedException e) {
logger.error("failed to get revision state", e);
}
return builtRevId;
}
private static String getParentRevId(SubversionChangeLogSet.LogEntry commit) {
String parentRevId = null;
try {
if (commit.getParent() != null && commit.getParent().getLogs() != null && commit.getParent().getLogs().size() > PARENT_COMMIT_INDEX) {
parentRevId = commit.getParent().getLogs().get(PARENT_COMMIT_INDEX).getCommitId();
} else {
logger.info("parent rev ID is not available in the commit's logs");
}
} catch (Exception e) {
logger.error("failed to retrieve parentRevId", e);
}
return parentRevId;
}
private static SCMRepository getSCMRepository(SubversionSCM svnData) {
String url = null;
if (svnData.getLocations().length > 0 && svnData.getLocations()[0] != null) {
url = svnData.getLocations()[0].getURL();
}
return dtoFactory.newDTO(SCMRepository.class)
.setType(SCMType.SVN)
.setUrl(url);
}
}