/* Copyright (c) 2013-2014 Boundless and others.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Distribution License v1.0
* which accompanies this distribution, and is available at
* https://www.eclipse.org/org/documents/edl-v10.html
*
* Contributors:
* Victor Olaya (Boundless) - initial implementation
*/
package org.locationtech.geogig.osm.internal;
import java.io.File;
import java.util.Iterator;
import java.util.List;
import org.junit.Rule;
import org.junit.Test;
import org.junit.rules.ExpectedException;
import org.junit.rules.TemporaryFolder;
import org.locationtech.geogig.api.porcelain.AddOp;
import org.locationtech.geogig.api.porcelain.CommitOp;
import org.locationtech.geogig.test.integration.RepositoryTestCase;
import org.openstreetmap.osmosis.core.container.v0_6.ChangeContainer;
import com.google.common.collect.Lists;
public class CreateOSMChangesetOpTest extends RepositoryTestCase {
@Rule
public ExpectedException exception = ExpectedException.none();
@Override
protected void setUpInternal() throws Exception {
repo.configDatabase().put("user.name", "groldan");
repo.configDatabase().put("user.email", "groldan@boundlessgeo.com");
}
@Rule
public TemporaryFolder tempFolder = new TemporaryFolder();
@Test
public void testCreateChangesets() throws Exception {
String filename = getClass().getResource("nodes_for_changeset.xml").getFile();
File file = new File(filename);
geogig.command(OSMImportOp.class).setDataSource(file.getAbsolutePath()).call();
long unstaged = geogig.getRepository().workingTree().countUnstaged("node").count();
assertTrue(unstaged > 0);
geogig.command(AddOp.class).call();
geogig.command(CommitOp.class).setMessage("commit1").call();
filename = getClass().getResource("nodes_for_changeset2.xml").getFile();
file = new File(filename);
geogig.command(OSMImportOp.class).setDataSource(file.getAbsolutePath()).call();
unstaged = geogig.getRepository().workingTree().countUnstaged("node").count();
assertTrue(unstaged > 0);
geogig.command(AddOp.class).call();
geogig.command(CommitOp.class).setMessage("commit2").call();
Iterator<ChangeContainer> changes = geogig.command(CreateOSMChangesetOp.class)
.setNewVersion("HEAD").setOldVersion("HEAD~1").call();
List<ChangeContainer> list = Lists.newArrayList(changes);
assertEquals(3, list.size());
}
@Test
public void testCreateChangesetsWithIdReplacement() throws Exception {
String filename = getClass().getResource("nodes_for_changeset.xml").getFile();
File file = new File(filename);
geogig.command(OSMImportOp.class).setDataSource(file.getAbsolutePath()).call();
long unstaged = geogig.getRepository().workingTree().countUnstaged("node").count();
assertTrue(unstaged > 0);
geogig.command(AddOp.class).call();
geogig.command(CommitOp.class).setMessage("commit1").call();
filename = getClass().getResource("nodes_for_changeset3.xml").getFile();
file = new File(filename);
geogig.command(OSMImportOp.class).setDataSource(file.getAbsolutePath()).call();
unstaged = geogig.getRepository().workingTree().countUnstaged("node").count();
assertTrue(unstaged > 0);
geogig.command(AddOp.class).call();
geogig.command(CommitOp.class).setMessage("commit2").call();
Iterator<ChangeContainer> changes = geogig.command(CreateOSMChangesetOp.class)
.setNewVersion("HEAD").setOldVersion("HEAD~1").setId(1l).call();
List<ChangeContainer> list = Lists.newArrayList(changes);
assertEquals(3, list.size());
assertEquals(1l, list.get(0).getEntityContainer().getEntity().getChangesetId());
}
}