liquibase.changelog.ChangeSetStatus Maven / Gradle / Ivy
package liquibase.changelog;
import liquibase.change.CheckSum;
import liquibase.changelog.filter.ChangeSetFilter;
import liquibase.changelog.filter.ChangeSetFilterResult;
import java.util.Date;
import java.util.Set;
/**
* Contains the current status of a ChangeSet. Normally returned by {@link liquibase.changelog.visitor.StatusVisitor}.
* Contains information on whether the changeSet has ran before and will run next time.
*/
public class ChangeSetStatus {
private final ChangeSet changeSet;
private final CheckSum currentCheckSum;
private String description;
private String comments;
private boolean willRun;
private Set filterResults;
private CheckSum storedCheckSum;
private Date dateLastExecuted;
private boolean previouslyRan;
private RanChangeSet ranChangeSet;
public ChangeSetStatus(ChangeSet changeSet) {
this.changeSet = changeSet;
this.currentCheckSum = changeSet.generateCheckSum();
this.description = changeSet.getDescription();
this.comments = changeSet.getComments();
}
public ChangeSet getChangeSet() {
return changeSet;
}
public CheckSum getCurrentCheckSum() {
return currentCheckSum;
}
/**
* ChangeSet description
*/
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
/**
* ChangeSet comments
*/
public String getComments() {
return comments;
}
public void setComments(String comments) {
this.comments = comments;
}
/**
* Will the change set run next time.
*/
public boolean getWillRun() {
return willRun;
}
public void setWillRun(boolean willRun) {
this.willRun = willRun;
}
/**
* Reasons the change set will or will not run next time. Returns empty set if no reasons were given
*/
public Set getFilterResults() {
return filterResults;
}
public void setFilterResults(Set filterResults) {
this.filterResults = filterResults;
}
/**
* Convenience method to check wither a given ChangeSetFilter type is a reason for running the change set or not.
*/
public boolean isFilteredBy(Class extends ChangeSetFilter> filterType) {
if (!willRun) {
return false;
}
if (filterResults == null) {
return false;
}
for (ChangeSetFilterResult result : filterResults) {
if (result.getFilter().equals(filterType)) {
return true;
}
}
return false;
}
/**
* Return the checksum stored from the last execution of the change set. Returns null if it has not ran before
*/
public CheckSum getStoredCheckSum() {
return storedCheckSum;
}
public void setStoredCheckSum(CheckSum storedCheckSum) {
this.storedCheckSum = storedCheckSum;
}
/**
* Return the date the change set was last executed. Returns null if it has not ran before
*/
public Date getDateLastExecuted() {
return dateLastExecuted;
}
public void setDateLastExecuted(Date dateLastExecuted) {
this.dateLastExecuted = dateLastExecuted;
}
/**
* Returns true if the change set was ran previously.
*/
public boolean getPreviouslyRan() {
return previouslyRan;
}
public void setPreviouslyRan(boolean previouslyRan) {
this.previouslyRan = previouslyRan;
}
public RanChangeSet getRanChangeSet() {
return ranChangeSet;
}
public void setRanChangeSet(RanChangeSet ranChangeSet) {
this.ranChangeSet = ranChangeSet;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy