Refactor JDeffered (#2559)

This commit is contained in:
Grzegorz Piwowarek 2017-09-05 19:59:42 +02:00 committed by GitHub
parent 7b836d9211
commit cafdf51bd7
8 changed files with 42 additions and 68 deletions

View File

@ -4,25 +4,21 @@ import org.jdeferred.Deferred;
import org.jdeferred.Promise; import org.jdeferred.Promise;
import org.jdeferred.impl.DeferredObject; import org.jdeferred.impl.DeferredObject;
public class FilterDemo { class FilterDemo {
static String modifiedMsg; private static String modifiedMsg;
public static String filter(String msg) { static String filter(String msg) {
Deferred<String, ?, ?> d = new DeferredObject<String, Object, Object>(); Deferred<String, ?, ?> d = new DeferredObject<>();
Promise<String, ?, ?> p = d.promise(); Promise<String, ?, ?> p = d.promise();
Promise<String, ?, ?> filtered = p.then((result) -> { Promise<String, ?, ?> filtered = p.then((result) -> {
modifiedMsg = "Hello " + result; modifiedMsg = "Hello " + result;
}); });
filtered.done((result) -> { filtered.done(r -> System.out.println("filtering done"));
System.out.println("filtering done");
});
d.resolve(msg); d.resolve(msg);
return modifiedMsg; return modifiedMsg;
} }
} }

View File

@ -5,35 +5,31 @@ import org.jdeferred.DonePipe;
import org.jdeferred.Promise; import org.jdeferred.Promise;
import org.jdeferred.impl.DeferredObject; import org.jdeferred.impl.DeferredObject;
public class PipeDemo { class PipeDemo {
public static enum Result { public enum Result {
SUCCESS, FAILURE SUCCESS, FAILURE
}; };
static Result status; private static Result status;
public static Result validate(int num) { static Result validate(int num) {
Deferred<Integer, ?, ?> d = new DeferredObject<Integer, Object, Object>(); Deferred<Integer, ?, ?> d = new DeferredObject<>();
Promise<Integer, ?, ?> p = d.promise(); Promise<Integer, ?, ?> p = d.promise();
p.then(new DonePipe<Integer, Integer, Exception, Void>() { p.then((DonePipe<Integer, Integer, Exception, Void>) result -> {
public Deferred<Integer, Exception, Void> pipeDone(Integer result) {
if (result < 90) { if (result < 90) {
return new DeferredObject<Integer, Exception, Void>().resolve(result); return new DeferredObject<Integer, Exception, Void>()
.resolve(result);
} else { } else {
return new DeferredObject<Integer, Exception, Void>().reject(new Exception("Unacceptable value")); return new DeferredObject<Integer, Exception, Void>()
.reject(new Exception("Unacceptable value"));
} }
} }).done(r -> status = Result.SUCCESS)
}).done((result) -> { .fail(r -> status = Result.FAILURE);
status = Result.SUCCESS;
}).fail((result) -> {
status = Result.FAILURE;
});
d.resolve(num); d.resolve(num);
return status; return status;
} }
} }

View File

@ -4,22 +4,17 @@ import org.jdeferred.Deferred;
import org.jdeferred.Promise; import org.jdeferred.Promise;
import org.jdeferred.impl.DeferredObject; import org.jdeferred.impl.DeferredObject;
public class PromiseDemo { class PromiseDemo {
public static void startJob(String jobName) { static void startJob(String jobName) {
Deferred<String, String, String> deferred = new DeferredObject<String, String, String>(); Deferred<String, String, String> deferred = new DeferredObject<>();
Promise<String, String, String> promise = deferred.promise(); Promise<String, String, String> promise = deferred.promise();
promise.done((result) -> { promise.done(result -> System.out.println("Job done"))
System.out.println("Job done"); .fail(rejection -> System.out.println("Job fail"))
}).fail((rejection) -> { .progress(progress -> System.out.println("Job is in progress"))
System.out.println("Job fail"); .always((state, result, rejection) -> System.out.println("Job execution started"));
}).progress((progress) -> {
System.out.println("Job is in progress");
}).always((state, result, rejection) -> {
System.out.println("Job execution started");
});
deferred.resolve(jobName); deferred.resolve(jobName);
// deferred.notify(""); // deferred.notify("");

View File

@ -10,13 +10,11 @@ public class ThreadSafeDemo {
public static void task() { public static void task() {
DeferredManager dm = new DefaultDeferredManager(); DeferredManager dm = new DefaultDeferredManager();
Deferred<String, String, String> deferred = new DeferredObject<String, String, String>(); Deferred<String, String, String> deferred = new DeferredObject<>();
Promise<String, String, String> p1 = deferred.promise(); Promise<String, String, String> p1 = deferred.promise();
Promise<String, String, String> p = dm.when(p1).done((result) -> { Promise<String, String, String> p = dm.when(p1)
System.out.println("done"); .done(r -> System.out.println("done"))
}).fail((result) -> { .fail(r -> System.out.println("fail"));
System.out.println("fail");
});
synchronized (p) { synchronized (p) {
while (p.isPending()) { while (p.isPending()) {

View File

@ -6,10 +6,10 @@ import org.jdeferred.Promise;
import org.jdeferred.impl.DefaultDeferredManager; import org.jdeferred.impl.DefaultDeferredManager;
import org.jdeferred.impl.DeferredObject; import org.jdeferred.impl.DeferredObject;
public class DeferredManagerDemo { class DeferredManagerDemo {
public static void initiate() { public static void initiate() {
Deferred<String, String, String> deferred = new DeferredObject<String, String, String>(); Deferred<String, String, String> deferred = new DeferredObject<>();
DeferredManager dm = new DefaultDeferredManager(); DeferredManager dm = new DefaultDeferredManager();
Promise<String, String, String> p1 = deferred.promise(), p2 = deferred.promise(), p3 = deferred.promise(); Promise<String, String, String> p1 = deferred.promise(), p2 = deferred.promise(), p3 = deferred.promise();
dm.when(p1, p2, p3).done((result) -> { dm.when(p1, p2, p3).done((result) -> {
@ -19,5 +19,4 @@ public class DeferredManagerDemo {
}); });
deferred.resolve("Hello Baeldung"); deferred.resolve("Hello Baeldung");
} }
} }

View File

@ -9,19 +9,16 @@ import org.jdeferred.Promise;
import org.jdeferred.impl.DefaultDeferredManager; import org.jdeferred.impl.DefaultDeferredManager;
import org.jdeferred.impl.DeferredObject; import org.jdeferred.impl.DeferredObject;
public class DeferredManagerWithExecutorDemo { class DeferredManagerWithExecutorDemo {
public static void initiate() { public static void initiate() {
ExecutorService executor = Executors.newFixedThreadPool(10); ExecutorService executor = Executors.newFixedThreadPool(10);
Deferred<String, String, String> deferred = new DeferredObject<String, String, String>(); Deferred<String, String, String> deferred = new DeferredObject<>();
DeferredManager dm = new DefaultDeferredManager(executor); DeferredManager dm = new DefaultDeferredManager(executor);
Promise<String, String, String> p1 = deferred.promise(), p2 = deferred.promise(), p3 = deferred.promise(); Promise<String, String, String> p1 = deferred.promise(), p2 = deferred.promise(), p3 = deferred.promise();
dm.when(p1, p2, p3).done((result) -> { dm.when(p1, p2, p3)
System.out.println("done"); .done(r -> System.out.println("done"))
}).fail((result) -> { .fail(r -> System.out.println("fail"));
System.out.println("fail");
});
deferred.resolve("done"); deferred.resolve("done");
} }
} }

View File

@ -3,17 +3,12 @@ package com.baeldung.jdeffered.manager;
import org.jdeferred.DeferredManager; import org.jdeferred.DeferredManager;
import org.jdeferred.impl.DefaultDeferredManager; import org.jdeferred.impl.DefaultDeferredManager;
public class SimpleDeferredManagerDemo { class SimpleDeferredManagerDemo {
public static void initiate() { public static void initiate() {
DeferredManager dm = new DefaultDeferredManager(); DeferredManager dm = new DefaultDeferredManager();
dm.when(() -> { dm.when(() -> 1)
return 1; .done(r -> System.out.println("done"))
}).done((result) -> { .fail(Throwable::printStackTrace);
System.out.println("done");
}).fail((e) -> {
e.printStackTrace();
});
} }
} }

View File

@ -1,8 +1,7 @@
package com.baeldung.jdeffered; package com.baeldung.jdeffered;
import org.junit.Test;
import com.baeldung.jdeffered.PipeDemo.Result; import com.baeldung.jdeffered.PipeDemo.Result;
import org.junit.Test;
import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertEquals;
@ -24,5 +23,4 @@ public class AppTest {
Result result = PipeDemo.validate(80); Result result = PipeDemo.validate(80);
assertEquals(result, Result.SUCCESS); assertEquals(result, Result.SUCCESS);
} }
} }