Skip to content

Commit

Permalink
* correct scope to test for mockito
Browse files Browse the repository at this point in the history
* JENKINS-11062: restore nextBuildNumber only if greater than current

git-svn-id: https://svn.jenkins-ci.org/trunk/hudson/plugins/thinBackup@39934 71c3de6d-444a-0410-be80-ed276b4c234a
  • Loading branch information
tofuatjava committed Sep 20, 2011
1 parent 68bd4ae commit 0317fbd
Show file tree
Hide file tree
Showing 2 changed files with 52 additions and 4 deletions.
2 changes: 1 addition & 1 deletion pom.xml
Expand Up @@ -82,7 +82,7 @@
<artifactId>mockito-all</artifactId>
<version>1.9.0-rc1</version>
<type>jar</type>
<scope>compile</scope>
<scope>test</scope>
</dependency>
</dependencies>
<distributionManagement>
Expand Down
Expand Up @@ -16,10 +16,17 @@
*/
package org.jvnet.hudson.plugins.thinbackup.restore;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileFilter;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.io.Writer;
import java.util.Collection;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;

Expand All @@ -28,6 +35,7 @@
import org.apache.commons.io.filefilter.FileFileFilter;
import org.apache.commons.io.filefilter.FileFilterUtils;
import org.apache.commons.io.filefilter.IOFileFilter;
import org.apache.commons.io.filefilter.TrueFileFilter;
import org.apache.commons.lang.StringUtils;
import org.jvnet.hudson.plugins.thinbackup.ThinBackupPeriodicWork.BackupType;
import org.jvnet.hudson.plugins.thinbackup.backup.BackupSet;
Expand Down Expand Up @@ -125,12 +133,52 @@ private boolean restoreFromZipFile() throws IOException {
}

private void restore(final File toRestore) throws IOException {
IOFileFilter restoreNextBuildNumberFilter = FileFilterUtils.trueFileFilter();
if (!restoreNextBuildNumber) {
restoreNextBuildNumberFilter = FileFilterUtils.notFileFilter(FileFilterUtils.nameFileFilter("nextBuildNumber"));
IOFileFilter nextBuildNumberFileFilter = FileFilterUtils.nameFileFilter("nextBuildNumber");
IOFileFilter restoreNextBuildNumberFilter = FileFilterUtils.notFileFilter(nextBuildNumberFileFilter);

if (restoreNextBuildNumber) {
Collection<File> restore = FileUtils.listFiles(toRestore, nextBuildNumberFileFilter, TrueFileFilter.INSTANCE);
Map<String, Integer> nextBuildNumbers = new HashMap<String, Integer>();
for (File file : restore) {
BufferedReader reader = null;
try {
reader = new BufferedReader(new FileReader(file));
nextBuildNumbers.put(file.getParent(), Integer.parseInt(reader.readLine()));
} finally {
if (reader != null)
reader.close();
}
}

Collection<File> current = FileUtils.listFiles(hudsonHome, nextBuildNumberFileFilter, TrueFileFilter.INSTANCE);
for (File file : current) {
BufferedReader reader = null;
try {
reader = new BufferedReader(new FileReader(file));
int currentBuildNumber = Integer.parseInt(reader.readLine());
Integer toRestoreNextBuildNumber = nextBuildNumbers.get(file.getParent());
if (currentBuildNumber < toRestoreNextBuildNumber)
restoreNextBuildNumber(file, toRestoreNextBuildNumber);
} finally {
if (reader != null)
reader.close();
}
}
}

FileUtils.copyDirectory(toRestore, this.hudsonHome, restoreNextBuildNumberFilter, true);
}

private void restoreNextBuildNumber(File file, Integer toRestoreNextBuildNumber) throws IOException {
file.delete();
file.createNewFile();
Writer writer = null;
try {
writer = new FileWriter(file);
writer.write(toRestoreNextBuildNumber);
} finally {
if (writer != null)
writer.close();
}
}
}

0 comments on commit 0317fbd

Please sign in to comment.