Exemple #1
0
 public void GetDirectoriesWithMecurialRepos_NoDrivesFound_ReturnsEmptyList()
 {
     var model = new CloneFromUsb();
         var drives = new List<IUsbDriveInfo>();
         model.DriveInfoRetriever = new RetrieveUsbDriveInfoForTests(drives);
         Assert.AreEqual(0, model.GetDirectoriesWithMecurialRepos().Count());
 }
        public GetCloneFromUsbDialog(string parentDirectoryToPutCloneIn)
        {
            _parentDirectoryToPutCloneIn = parentDirectoryToPutCloneIn;
            Font = SystemFonts.MessageBoxFont;

            InitializeComponent();
            _model = new CloneFromUsb();
            UpdateDisplay(State.LookingForUsb);
            _progress = _logBox;
        }
        public GetCloneFromUsbDialog(string parentDirectoryToPutCloneIn)
        {
            _parentDirectoryToPutCloneIn = parentDirectoryToPutCloneIn;
            Font = SystemFonts.MessageBoxFont;

            InitializeComponent();
            _model = new CloneFromUsb();
            UpdateDisplay(State.LookingForUsb);
            _progress = _logBox;
        }
Exemple #4
0
 public void GetDirectoriesWithMecurialRepos_OneDriveAndDirectoryButNotRep_ReturnsEmptyList()
 {
     using (var usb = new TemporaryFolder("clonetestUsb"))
     {
         Directory.CreateDirectory(usb.Combine("tests"));
         var model = new CloneFromUsb();
         var drives = new List<IUsbDriveInfo>();
         drives.Add(new UsbDriveInfoForTests(usb.Path));
         model.DriveInfoRetriever = new RetrieveUsbDriveInfoForTests(drives);
         Assert.AreEqual(0, model.GetDirectoriesWithMecurialRepos().Count());
     }
 }
Exemple #5
0
 public void GetDirectoriesWithMecurialRepos_OneDriveOneRepo_ReturnsRepoPath()
 {
     using (var usb = new TemporaryFolder("clonetestUsb"))
     {
         Directory.CreateDirectory(usb.Combine("test"));
         Directory.CreateDirectory(usb.Combine("testrepo",".hg"));
         var model = new CloneFromUsb();
         var drives = new List<IUsbDriveInfo>();
         drives.Add(new UsbDriveInfoForTests(usb.Path));
         model.DriveInfoRetriever = new RetrieveUsbDriveInfoForTests(drives);
         Assert.AreEqual(1, model.GetDirectoriesWithMecurialRepos().Count());
         Assert.AreEqual(usb.Combine("testrepo"), model.GetDirectoriesWithMecurialRepos().First());
     }
 }
Exemple #6
0
 public void GetDirectoriesWithMecurialRepos_TwoRepos_ReturnsOnlyUnfilteredPath()
 {
     using (var usb = new TemporaryFolder("clonetestUsb"))
     {
         Directory.CreateDirectory(usb.Combine("test1"));
         Directory.CreateDirectory(usb.Combine("test1", ".hg"));
         Directory.CreateDirectory(usb.Combine("testSKIP"));
         Directory.CreateDirectory(usb.Combine("testSKIP", ".hg"));
         var model = new CloneFromUsb();
         var drives = new List<IUsbDriveInfo>();
         drives.Add(new UsbDriveInfoForTests(usb.Path));
         model.DriveInfoRetriever = new RetrieveUsbDriveInfoForTests(drives);
         model.ProjectFilter = path => !path.Contains("SKIP");
         Assert.AreEqual(1, model.GetDirectoriesWithMecurialRepos().Count());
     }
 }
Exemple #7
0
 public void MakeListItem_MakesNormalItem()
 {
     using (var usb = new TemporaryFolder("clonetestUsb"))
     {
         var path = usb.Combine("test1");
         Directory.CreateDirectory(path);
         Directory.CreateDirectory(usb.Combine("test1", ".hg"));
         var model = new CloneFromUsb();
         var item = model.CreateListItemFor(path);
         Assert.That(item, Is.Not.Null, "model should have made a list item");
         Assert.That(item.Text, Is.EqualTo("test1"));
         Assert.That(item.Tag, Is.EqualTo(path));
         var last = File.GetLastWriteTime(path);
         string expectedSubitem = last.ToShortDateString() + " " + last.ToShortTimeString(); // Not a great test, basically duplicates the impl
         Assert.That(item.SubItems[1].Text, Is.EqualTo(expectedSubitem));
         Assert.That(item.ToolTipText, Is.EqualTo(path));
         Assert.That(item.ImageIndex, Is.EqualTo(0));
         Assert.That(item.BackColor, Is.EqualTo(Color.FromKnownColor(KnownColor.Window)));
         Assert.That(item.ForeColor, Is.EqualTo(Color.FromKnownColor(KnownColor.WindowText)));
     }
 }
Exemple #8
0
        public void MakeListItemWhenRepoInUse_MakesDisabledItem()
        {
            using (var setup = new RepositorySetup("Dan"))
            {
                // Set a project up sufficiently to have an ID.
                var tempFilePath = setup.ProjectFolder.Combine("test.1w1");
                File.WriteAllText(tempFilePath, "hello");
                setup.ProjectFolderConfig.IncludePatterns.Clear();
                setup.ProjectFolderConfig.ExcludePatterns.Clear();
                setup.ProjectFolderConfig.IncludePatterns.Add("*.1w1");
                setup.AddAndCheckIn(); // Need to have one commit.
                var id = setup.Repository.Identifier;
                var path = setup.Repository.PathToRepo;

                var model = new CloneFromUsb();
                model.ReposInUse = new Dictionary<string, string>();
                model.ReposInUse[id] = "myname";
                var item = model.CreateListItemFor(path);
                Assert.That(item, Is.Not.Null, "model should have made a list item");
                Assert.That(item.Text, Is.EqualTo(Path.GetFileName(path)));
                Assert.That(item.Tag, Is.EqualTo(path));
                var last = File.GetLastWriteTime(path);
                string expectedSubitem = last.ToShortDateString() + " " + last.ToShortTimeString();
                // Not a great test, basically duplicates the impl
                Assert.That(item.SubItems[1].Text, Is.EqualTo(expectedSubitem));
                Assert.That(item.ToolTipText, Is.EqualTo(string.Format(CloneFromUsb.ProjectInUseTemplate, "myname")));
                Assert.That(item.ImageIndex, Is.EqualTo(1));
                Assert.That(item.ForeColor, Is.EqualTo(CloneFromUsb.DisabledItemForeColor));
            }
        }
Exemple #9
0
 public void MakeListItemWhenAlreadyHaveProjectName_MakesDisabledItem()
 {
     using (var usb = new TemporaryFolder("clonetestUsb"))
     {
         var path = usb.Combine("test1");
         Directory.CreateDirectory(path);
         Directory.CreateDirectory(usb.Combine("test1", ".hg"));
         var model = new CloneFromUsb();
         model.ExistingProjects = new HashSet<string> {"test1"};
         var item = model.CreateListItemFor(path);
         Assert.That(item, Is.Not.Null, "model should have made a list item");
         Assert.That(item.Text, Is.EqualTo("test1"));
         Assert.That(item.Tag, Is.EqualTo(path));
         var last = File.GetLastWriteTime(path);
         string expectedSubitem = last.ToShortDateString() + " " + last.ToShortTimeString();
             // Not a great test, basically duplicates the impl
         Assert.That(item.SubItems[1].Text, Is.EqualTo(expectedSubitem));
         Assert.That(item.ToolTipText, Is.EqualTo(CloneFromUsb.ProjectWithSameNameExists));
         Assert.That(item.ImageIndex, Is.EqualTo(2));
         Assert.That(item.ForeColor, Is.EqualTo(CloneFromUsb.DisabledItemForeColor));
     }
 }
Exemple #10
0
        public void MakeClone_TargetExists_CreatesCloneInWhenTargetIsEmpty()
        {
            using (var repo = new RepositorySetup("source"))
            using (var f = new TemporaryFolder("clonetest"))
            {
                var model = new CloneFromUsb();
                var progress = new ConsoleProgress();
                progress.ShowVerbose = true;
                var extantFolder = f.Combine(RepositorySetup.ProjectName);
                Directory.CreateDirectory(extantFolder);

                var cloneFolder = model.MakeClone(repo.ProjectFolder.Path, f.Path, progress);
                Assert.AreEqual(extantFolder, cloneFolder);
                Assert.IsTrue(Directory.Exists(extantFolder));
                Assert.IsFalse(Directory.Exists(extantFolder + "1"));
            }
        }
Exemple #11
0
        public void MakeClone_TargetExists_CreatesCloneInAnotherFolder()
        {
            using (var repo = new RepositorySetup("source"))
            using (var f = new TemporaryFolder("clonetest"))
            {
                var model = new CloneFromUsb();
                var progress = new ConsoleProgress();
                progress.ShowVerbose = true;
                var extantFolder = f.Combine(RepositorySetup.ProjectName);
                Directory.CreateDirectory(extantFolder);
                // Make a subfolder, which will force it to make a new folder, since an empty folder is deleted.
                var extantSubfolderPath = Path.Combine(extantFolder, "ChildFolder");
                Directory.CreateDirectory(extantSubfolderPath);

                var cloneFolder = model.MakeClone(repo.ProjectFolder.Path, f.Path, progress);
                Assert.AreEqual(extantFolder + "1", cloneFolder);
                Assert.IsTrue(Directory.Exists(extantFolder + "1"));
            }
        }
Exemple #12
0
 public void MakeClone_NoProblems_MakesClone()
 {
     using(var repo = new RepositorySetup("source"))
     using (var f = new TemporaryFolder("clonetest"))
     {
         var model = new CloneFromUsb();
         var progress = new ConsoleProgress();
         progress.ShowVerbose = true;
         model.MakeClone(repo.ProjectFolder.Path, f.Path, progress);
         Assert.IsTrue(Directory.Exists(f.Combine(RepositorySetup.ProjectName, ".hg")));
     }
 }
Exemple #13
0
 public void GetDirectoriesWithMecurialRepos_WithRepo2DeepIsNotFound()
 {
     using (var usb1 = new TemporaryFolder("clonetestUsb1"))
     {
         Directory.CreateDirectory(usb1.Combine("a", "repo1", ".hg"));
         var model = new CloneFromUsb();
         var drives = new List<IUsbDriveInfo>();
         drives.Add(new UsbDriveInfoForTests(usb1.Path));
         model.DriveInfoRetriever = new RetrieveUsbDriveInfoForTests(drives);
         Assert.AreEqual(0, model.GetDirectoriesWithMecurialRepos().Count());
     }
 }