From 84e456c5dc30c3749f68b7ef554f5a7206cdde27 Mon Sep 17 00:00:00 2001 From: dotasek Date: Wed, 29 Nov 2023 10:35:49 -0500 Subject: [PATCH] Actual assertion for test --- .../npm/FilesystemPackageManagerTests.java | 42 ++++++++++--------- 1 file changed, 23 insertions(+), 19 deletions(-) diff --git a/org.hl7.fhir.utilities/src/test/java/org/hl7/fhir/utilities/npm/FilesystemPackageManagerTests.java b/org.hl7.fhir.utilities/src/test/java/org/hl7/fhir/utilities/npm/FilesystemPackageManagerTests.java index 470e3cde8..3d4bd0dda 100644 --- a/org.hl7.fhir.utilities/src/test/java/org/hl7/fhir/utilities/npm/FilesystemPackageManagerTests.java +++ b/org.hl7.fhir.utilities/src/test/java/org/hl7/fhir/utilities/npm/FilesystemPackageManagerTests.java @@ -7,6 +7,7 @@ import java.io.IOException; import java.nio.file.Files; import java.util.ArrayList; import java.util.List; +import java.util.concurrent.atomic.AtomicInteger; import javax.annotation.Nonnull; @@ -104,32 +105,35 @@ public class FilesystemPackageManagerTests { } @Test - public void multithreadTest() throws IOException { - String pcmPath = Files.createTempDirectory("pcm-multithreadTest").toFile().getAbsolutePath(); + public void multithreadingTest() throws IOException { + String pcmPath = Files.createTempDirectory("fpcm-multithreadingTest").toFile().getAbsolutePath(); FilesystemPackageCacheManager pcm = new FilesystemPackageCacheManager(pcmPath); - + + final AtomicInteger totalSuccessful = new AtomicInteger(); + List threads = new ArrayList<>(); - for (int i = 0 ; i < 3 ; i++) { + for (int i = 0; i < 3; i++) { final int index = i; Thread t = new Thread(() -> { - - try { - pcm.loadPackage("hl7.fhir.r4.core#4.0.1"); - System.out.println("Thread " + index + " completed"); - } catch (Exception e) { - e.printStackTrace(); - System.err.println("Thread " + index + " failed"); - } - }); + try { + pcm.loadPackage("hl7.fhir.r4.core#4.0.1"); + totalSuccessful.incrementAndGet(); + System.out.println("Thread " + index + " completed"); + } catch (Exception e) { + e.printStackTrace(); + System.err.println("Thread " + index + " failed"); + } + }); t.start(); threads.add(t); } - threads.forEach(t -> { - try { - t.join(); - } catch (InterruptedException e) { + threads.forEach(t -> { + try { + t.join(); + } catch (InterruptedException e) { - } - }); + } + }); + assertEquals(3, totalSuccessful.get()); } }