changeset 478:e74580e24feb

Test for subprogress
author Artem Tikhomirov <tikhomirov.artem@gmail.com>
date Thu, 12 Jul 2012 19:11:12 +0200 (2012-07-12)
parents 9c9d09111aee
children 59b7c817bc4d
files cmdline/org/tmatesoft/hg/console/Main.java test/org/tmatesoft/hg/test/OutputParser.java test/org/tmatesoft/hg/test/TestAuxUtilities.java
diffstat 3 files changed, 52 insertions(+), 38 deletions(-) [+]
line wrap: on
line diff
--- a/cmdline/org/tmatesoft/hg/console/Main.java	Thu Jul 12 18:07:51 2012 +0200
+++ b/cmdline/org/tmatesoft/hg/console/Main.java	Thu Jul 12 19:11:12 2012 +0200
@@ -106,7 +106,6 @@
 	public static void main(String[] args) throws Exception {
 		Main m = new Main(args);
 //		m.checkWalkFileRevisions();
-//		m.checkSubProgress();
 //		m.buildFileLog();
 //		m.testConsoleLog();
 //		m.testTreeTraversal();
@@ -134,42 +133,6 @@
 		//  hg --debug manifest --rev 150 | grep cmdline/org/tmatesoft/hg/console/Main.java
 		hgRepo.getManifest().walkFileRevisions(Path.create("cmdline/org/tmatesoft/hg/console/Main.java"), new ManifestDump(), 100, 150, 200, 210, 300);
 	}
-	
-	// no repo
-	// FIXME as test, perhaps in TestAuxUtilities
-	private void checkSubProgress() {
-		ProgressSupport ps = new ProgressSupport() {
-			private int units;
-			
-			public void start(int totalUnits) {
-				units = totalUnits;
-				System.out.printf("%d:", totalUnits);
-				
-			}
-			public void worked(int wu) {
-				for (int i = 0; i < wu; i++) {
-					System.out.print(units-- == 0 ? '!' : '.');
-				}
-			}
-			public void done() {
-				System.out.println("DONE");
-			}
-		};
-		ps.start(10);
-		ProgressSupport.Sub s1 = new ProgressSupport.Sub(ps, 3);
-		ProgressSupport.Sub s2 = new ProgressSupport.Sub(ps, 7);
-		s1.start(10);
-		s1.worked(1);
-		s1.worked(2);
-		s1.worked(3);
-		s1.worked(4);
-		s1.done();
-		//
-		s2.start(5);
-		s2.worked(3);
-		s2.worked(2);
-		s2.done();
-	}
 
 	private void buildFileLog() throws Exception {
 		final long start = System.nanoTime();
--- a/test/org/tmatesoft/hg/test/OutputParser.java	Thu Jul 12 18:07:51 2012 +0200
+++ b/test/org/tmatesoft/hg/test/OutputParser.java	Thu Jul 12 19:11:12 2012 +0200
@@ -71,7 +71,7 @@
 
 				public String next() {
 					if (next) {
-						String rv = m.group();
+						String rv = m.group(1);
 						next = m.find();
 						return rv;
 					}
--- a/test/org/tmatesoft/hg/test/TestAuxUtilities.java	Thu Jul 12 18:07:51 2012 +0200
+++ b/test/org/tmatesoft/hg/test/TestAuxUtilities.java	Thu Jul 12 19:11:12 2012 +0200
@@ -48,6 +48,7 @@
 import org.tmatesoft.hg.util.CancelledException;
 import org.tmatesoft.hg.util.Pair;
 import org.tmatesoft.hg.util.Path;
+import org.tmatesoft.hg.util.ProgressSupport;
 
 /**
  *
@@ -84,6 +85,56 @@
 		}
 		return rebuilt;
 	}
+	
+
+	@Test
+	public void checkSubProgress() {
+		// no repo
+		class PS implements ProgressSupport {
+			
+			@SuppressWarnings("unused")
+			public int units;
+			public int worked;
+			public boolean done = false;
+			
+			public void start(int totalUnits) {
+				units = totalUnits;
+			}
+			public void worked(int wu) {
+				worked += wu;
+			}
+			public void done() {
+				done = true;
+			}
+		};
+		PS ps = new PS();
+		ps.start(10);
+		ProgressSupport.Sub s1 = new ProgressSupport.Sub(ps, 3);
+		ProgressSupport.Sub s2 = new ProgressSupport.Sub(ps, 7);
+		s1.start(10);
+		s1.worked(1);
+		s1.worked(1);
+		s1.worked(1);
+		s1.worked(1);
+		// so far s1 consumed 40% of total 3 units
+		assertEquals(1, ps.worked);
+		s1.done();
+		// now s1 consumed 100% of total 3 units
+		assertEquals(3, ps.worked);
+		assertFalse(ps.done);
+		//
+		s2.start(5);
+		s2.worked(3);
+		// s2 consumed 60% (3/5) of ps's 7 units
+		// 3+4 == 3 from s1 + 0.6*7 
+		assertEquals(3 + 4, ps.worked);
+		s2.worked(2);
+		assertEquals(3 + 7, ps.worked);
+		assertFalse(ps.done);
+		s2.done();
+		//assertTrue(ps.done);
+	}
+
 
 	static class CancelImpl implements CancelSupport {
 		private boolean shallStop = false;