mirror of
https://github.com/corda/corda.git
synced 2025-01-09 06:23:04 +00:00
move Continuations and Coroutines tests to top-level test directory
This commit is contained in:
parent
e35047b056
commit
db91c27441
@ -1,5 +1,3 @@
|
|||||||
package extra;
|
|
||||||
|
|
||||||
import static avian.Continuations.callWithCurrentContinuation;
|
import static avian.Continuations.callWithCurrentContinuation;
|
||||||
|
|
||||||
import avian.CallbackReceiver;
|
import avian.CallbackReceiver;
|
@ -1,5 +1,3 @@
|
|||||||
package extra;
|
|
||||||
|
|
||||||
import static avian.Continuations.callWithCurrentContinuation;
|
import static avian.Continuations.callWithCurrentContinuation;
|
||||||
|
|
||||||
import avian.CallbackReceiver;
|
import avian.CallbackReceiver;
|
||||||
@ -11,15 +9,28 @@ public class Coroutines {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static void produce(Consumer<Character> consumer) throws Exception {
|
private static void produce(Consumer<Character> consumer) throws Exception {
|
||||||
|
System.out.println("produce \"a\"");
|
||||||
consumer.consume('a');
|
consumer.consume('a');
|
||||||
|
|
||||||
|
System.out.println("produce \"b\"");
|
||||||
consumer.consume('b');
|
consumer.consume('b');
|
||||||
|
|
||||||
|
System.out.println("produce \"c\"");
|
||||||
consumer.consume('c');
|
consumer.consume('c');
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void consume(Producer<Character> producer) throws Exception {
|
private static void consume(Producer<Character> producer) throws Exception {
|
||||||
expect(producer.produce() == 'a');
|
char v = producer.produce();
|
||||||
expect(producer.produce() == 'b');
|
System.out.println("consume \"" + v + "\"");
|
||||||
expect(producer.produce() == 'c');
|
expect(v == 'a');
|
||||||
|
|
||||||
|
v = producer.produce();
|
||||||
|
System.out.println("consume \"" + v + "\"");
|
||||||
|
expect(v == 'b');
|
||||||
|
|
||||||
|
v = producer.produce();
|
||||||
|
System.out.println("consume \"" + v + "\"");
|
||||||
|
expect(v == 'c');
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void main(String[] args) throws Exception {
|
public static void main(String[] args) throws Exception {
|
||||||
@ -40,8 +51,8 @@ public class Coroutines {
|
|||||||
};
|
};
|
||||||
|
|
||||||
final Producer<Character> producer = new Producer<Character>() {
|
final Producer<Character> producer = new Producer<Character>() {
|
||||||
public Character produce() throws Exception {
|
final CallbackReceiver<Character> receiver
|
||||||
return callWithCurrentContinuation(new CallbackReceiver<Character>() {
|
= new CallbackReceiver<Character>() {
|
||||||
public Character receive(Callback<Character> continuation)
|
public Character receive(Callback<Character> continuation)
|
||||||
throws Exception
|
throws Exception
|
||||||
{
|
{
|
||||||
@ -55,7 +66,10 @@ public class Coroutines {
|
|||||||
|
|
||||||
throw new AssertionError();
|
throw new AssertionError();
|
||||||
}
|
}
|
||||||
});
|
};
|
||||||
|
|
||||||
|
public Character produce() throws Exception {
|
||||||
|
return callWithCurrentContinuation(receiver);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in New Issue
Block a user