/******************************************************************************* * Copyright (C) 2010, 2013 Dariusz Luksza <dariusz@luksza.org> and others. * * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html *******************************************************************************/ package org.eclipse.egit.core.synchronize; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertTrue; import java.io.File; import java.io.IOException; import org.eclipse.core.resources.IFile; import org.eclipse.core.resources.IResource; import org.eclipse.core.runtime.NullProgressMonitor; import org.eclipse.egit.core.synchronize.dto.GitSynchronizeData; import org.eclipse.egit.core.synchronize.dto.GitSynchronizeDataSet; import org.eclipse.egit.core.test.GitTestCase; import org.eclipse.egit.core.test.TestRepository; import org.eclipse.jgit.lib.Constants; import org.eclipse.jgit.revwalk.RevCommit; import org.eclipse.team.core.TeamException; import org.eclipse.team.core.variants.IResourceVariant; import org.eclipse.team.core.variants.IResourceVariantTree; import org.junit.After; import org.junit.Before; import org.junit.Test; public class GitResourceVariantTreeSubscriberTest extends GitTestCase { private static final String MASTER = Constants.R_HEADS + Constants.MASTER; private static final String BRANCH = Constants.R_HEADS + "branch"; private TestRepository testRepo; private RevCommit initialCommit; private RevCommit commitBranch; private RevCommit commitMaster; private IFile changedFile; @Override @Before public void setUp() throws Exception { super.setUp(); testRepo = new TestRepository(gitDir); testRepo.connect(project.getProject()); String fileName = "Main.java"; File file = testRepo.createFile(project.getProject(), fileName); initialCommit = testRepo.appendContentAndCommit(project.getProject(), file, "class Main {}", "initial commit"); changedFile = testRepo.getIFile(project.getProject(), file); testRepo.createAndCheckoutBranch(Constants.HEAD, BRANCH); commitBranch = testRepo.appendContentAndCommit(project.getProject(), file, "// test 1", "second commit"); testRepo.checkoutBranch(MASTER); commitMaster = testRepo.appendContentAndCommit(project.getProject(), file, "// test 2", "third commit"); } @After public void clearGitResources() throws Exception { testRepo.dispose(); super.tearDown(); } @Test public void testSyncLocalAndBranch() throws Exception { // Note that HEAD is on master GitResourceVariantTreeSubscriber grvts = createGitResourceVariantTreeSubscriber( Constants.HEAD, BRANCH, true); grvts.init(new NullProgressMonitor()); IResourceVariant actualSource = getSourceVariant(grvts, changedFile, true); IResourceVariant actualBase = getBaseVariant(grvts, changedFile); IResourceVariant actualRemote = getRemoteVariant(grvts, changedFile); assertVariantIsLocal(actualSource, changedFile); assertVariantMatchCommit(actualBase, initialCommit); assertVariantMatchCommit(actualRemote, commitBranch); } @Test public void testSyncMasterAndBranch() throws Exception { GitResourceVariantTreeSubscriber grvts = createGitResourceVariantTreeSubscriber( MASTER, BRANCH, false); grvts.init(new NullProgressMonitor()); IResourceVariant actualSource = getSourceVariant(grvts, changedFile, false); IResourceVariant actualBase = getBaseVariant(grvts, changedFile); IResourceVariant actualRemote = getRemoteVariant(grvts, changedFile); assertVariantMatchCommit(actualSource, commitMaster); assertVariantMatchCommit(actualBase, initialCommit); assertVariantMatchCommit(actualRemote, commitBranch); } @Test public void testSyncBranchAndMaster() throws Exception { GitResourceVariantTreeSubscriber grvts = createGitResourceVariantTreeSubscriber( BRANCH, MASTER, false); grvts.init(new NullProgressMonitor()); IResourceVariant actualSource = getSourceVariant(grvts, changedFile, false); IResourceVariant actualBase = getBaseVariant(grvts, changedFile); IResourceVariant actualRemote = getRemoteVariant(grvts, changedFile); assertVariantMatchCommit(actualSource, commitBranch); assertVariantMatchCommit(actualBase, initialCommit); assertVariantMatchCommit(actualRemote, commitMaster); } private void assertVariantIsLocal(IResourceVariant variant, IResource local) { assertTrue(variant instanceof GitLocalResourceVariant); assertEquals(local, ((GitLocalResourceVariant) variant).getResource()); } private void assertVariantMatchCommit(IResourceVariant variant, RevCommit commit) { assertTrue(variant instanceof GitRemoteResource); assertEquals(commit, ((GitRemoteResource) variant).getCommitId()); } private GitResourceVariantTreeSubscriber createGitResourceVariantTreeSubscriber( String src, String dst, boolean includeLocal) throws IOException { GitSynchronizeData gsd = new GitSynchronizeData( testRepo.getRepository(), src, dst, includeLocal); GitSynchronizeDataSet gsds = new GitSynchronizeDataSet(gsd); return new GitResourceVariantTreeSubscriber(gsds); } private IResourceVariant getSourceVariant( GitResourceVariantTreeSubscriber subscriber, IResource resource, boolean includeLocal) throws TeamException { IResourceVariantTree tree = subscriber.getSourceTree(); assertNotNull(tree); assertTrue(tree instanceof GitSourceResourceVariantTree); IResourceVariant resourceVariant = tree.getResourceVariant(resource); assertNotNull(resourceVariant); if (includeLocal) assertTrue(resourceVariant instanceof GitLocalResourceVariant); else assertTrue(resourceVariant instanceof GitRemoteResource); return resourceVariant; } private IResourceVariant getBaseVariant( GitResourceVariantTreeSubscriber subscriber, IResource resource) throws TeamException { IResourceVariantTree tree = subscriber.getBaseTree(); assertNotNull(tree); assertTrue(tree instanceof GitBaseResourceVariantTree); IResourceVariant resourceVariant = tree .getResourceVariant(resource); assertNotNull(resourceVariant); assertTrue(resourceVariant instanceof GitRemoteResource); return resourceVariant; } private IResourceVariant getRemoteVariant( GitResourceVariantTreeSubscriber subscriber, IResource resource) throws TeamException { IResourceVariantTree tree = subscriber.getRemoteTree(); assertNotNull(tree); assertTrue(tree instanceof GitRemoteResourceVariantTree); IResourceVariant resourceVariant = tree.getResourceVariant(resource); assertNotNull(resourceVariant); assertTrue(resourceVariant instanceof GitRemoteResource); return resourceVariant; } }