Skip to content

Commit

Permalink
[fix][test] Fix test testAsyncFunctionMaxPending (apache#22121)
Browse files Browse the repository at this point in the history
  • Loading branch information
liangyepianzhou authored Feb 27, 2024
1 parent 3013496 commit 91de98a
Showing 1 changed file with 9 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
import static org.testng.Assert.assertNull;
import static org.testng.Assert.assertSame;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import lombok.Cleanup;
Expand Down Expand Up @@ -185,6 +186,7 @@ public void testUserExceptionThrowingAsyncFunction() throws Exception {

@Test
public void testAsyncFunctionMaxPending() throws Exception {
CountDownLatch count = new CountDownLatch(1);
InstanceConfig instanceConfig = new InstanceConfig();
int pendingQueueSize = 3;
instanceConfig.setMaxPendingAsyncRequests(pendingQueueSize);
Expand All @@ -196,7 +198,7 @@ public void testAsyncFunctionMaxPending() throws Exception {
CompletableFuture<String> result = new CompletableFuture<>();
executor.submit(() -> {
try {
Thread.sleep(500);
count.await();
result.complete(String.format("%s-lambda", input));
} catch (Exception e) {
result.completeExceptionally(e);
Expand All @@ -222,8 +224,13 @@ public void testAsyncFunctionMaxPending() throws Exception {
// no space left
assertEquals(0, instance.getPendingAsyncRequests().remainingCapacity());

AsyncFuncRequest[] asyncFuncRequests = new AsyncFuncRequest[3];
for (int i = 0; i < 3; i++) {
AsyncFuncRequest request = instance.getPendingAsyncRequests().poll();
asyncFuncRequests[i] = instance.getPendingAsyncRequests().poll();
}

count.countDown();
for (AsyncFuncRequest request : asyncFuncRequests) {
Assert.assertEquals(request.getProcessResult().get(), testString + "-lambda");
}

Expand Down

0 comments on commit 91de98a

Please sign in to comment.