From a1c3c677f9e628f4f092c548858633d29fcf83ca Mon Sep 17 00:00:00 2001 From: timofeevmd Date: Tue, 19 Mar 2024 16:27:29 +0400 Subject: [PATCH 1/2] update metrics Signed-off-by: timofeevmd --- .gitignore | 3 ++- .../java/jp/co/soramitsu/load/LoadProfiles.java | 14 ++++++++++++++ .../soramitsu/load/TechicalScns/TransactionOnly.kt | 2 ++ 3 files changed, 18 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index 53c4b7d..ec4d461 100644 --- a/.gitignore +++ b/.gitignore @@ -3,4 +3,5 @@ /target/ /logs/*.log /iroha2-per.iml -/src/mint_asset_for_created_user_trigger/target/ \ No newline at end of file +/src/mint_asset_for_created_user_trigger/target/ +/iroha2-perf.iml \ No newline at end of file diff --git a/src/main/java/jp/co/soramitsu/load/LoadProfiles.java b/src/main/java/jp/co/soramitsu/load/LoadProfiles.java index 11e6f3d..88ae890 100644 --- a/src/main/java/jp/co/soramitsu/load/LoadProfiles.java +++ b/src/main/java/jp/co/soramitsu/load/LoadProfiles.java @@ -14,6 +14,15 @@ public static ClosedInjectionStep getMaxPerformanceClosedProfile() { .separatedByRampsLasting(SimulationConfig.simulation.separatedByRampsLasting()) .startingFrom(SimulationConfig.simulation.startingFrom()); } + + public static OpenInjectionStep getMaxPerformanceOpenProfile() { + return incrementUsersPerSec(SimulationConfig.simulation.concurrentUsers()) + .times(SimulationConfig.simulation.times()) + .eachLevelLasting(SimulationConfig.simulation.stageDuration()) + .separatedByRampsLasting(SimulationConfig.simulation.rampDuration()) + .startingFrom(0); + } + public static ClosedInjectionStep[] getStabilityClosedProfile() { return new ClosedInjectionStep[]{ rampConcurrentUsers(0).to(SimulationConfig.simulation.intensity()).during(SimulationConfig.simulation.rampDuration()), @@ -43,4 +52,9 @@ public static OpenInjectionStep[] setupModel(){ atOnceUsers(SimulationConfig.simulation.domainSetUpRumpUp()) }; } + public static OpenInjectionStep[] getStabilityOpenProfile() { + return new OpenInjectionStep[]{ + constantUsersPerSec(SimulationConfig.simulation.intensity()).during(SimulationConfig.simulation.stageDuration()) + }; + } } diff --git a/src/main/kotlin/jp/co/soramitsu/load/TechicalScns/TransactionOnly.kt b/src/main/kotlin/jp/co/soramitsu/load/TechicalScns/TransactionOnly.kt index 29583f0..31ee0b3 100644 --- a/src/main/kotlin/jp/co/soramitsu/load/TechicalScns/TransactionOnly.kt +++ b/src/main/kotlin/jp/co/soramitsu/load/TechicalScns/TransactionOnly.kt @@ -2,6 +2,7 @@ package jp.co.soramitsu.load.TechicalScns import io.gatling.javaapi.core.CoreDsl import io.gatling.javaapi.core.ScenarioBuilder +import io.prometheus.client.Histogram import jp.co.soramitsu.iroha2.client.blockstream.BlockStreamStorage import jp.co.soramitsu.iroha2.client.blockstream.BlockStreamSubscription import jp.co.soramitsu.load.infrastructure.config.SimulationConfig @@ -42,6 +43,7 @@ class TransactionOnly: Wrench13() { Session } .exec { Session -> + var timer: Histogram.Timer val iroha2Client = buildClient(SimulationConfig.simulation.configuration()) timer = CustomMetrics.subscriptionToBlockStreamTimer.labels( "gatling", From d77ff2a938480ecae34c858a1196aab01ea71dae Mon Sep 17 00:00:00 2001 From: timofeevmd Date: Tue, 19 Mar 2024 17:49:24 +0400 Subject: [PATCH 2/2] update load model Signed-off-by: timofeevmd --- .../java/jp/co/soramitsu/load/LoadProfiles.java | 13 ++++++++----- .../transaction/PerformanceSimulation.java | 3 ++- 2 files changed, 10 insertions(+), 6 deletions(-) diff --git a/src/main/java/jp/co/soramitsu/load/LoadProfiles.java b/src/main/java/jp/co/soramitsu/load/LoadProfiles.java index 88ae890..37a8680 100644 --- a/src/main/java/jp/co/soramitsu/load/LoadProfiles.java +++ b/src/main/java/jp/co/soramitsu/load/LoadProfiles.java @@ -29,6 +29,13 @@ public static ClosedInjectionStep[] getStabilityClosedProfile() { constantConcurrentUsers(SimulationConfig.simulation.intensity()).during(SimulationConfig.simulation.stageDuration()) }; } + + public static OpenInjectionStep[] getStabilityOpenProfile() { + return new OpenInjectionStep[]{ + constantUsersPerSec(SimulationConfig.simulation.intensity()).during(SimulationConfig.simulation.stageDuration()) + }; + } + public static ClosedInjectionStep[] getStressClosedProfile() { return new ClosedInjectionStep[]{ rampConcurrentUsers(0).to(SimulationConfig.simulation.intensity()).during(SimulationConfig.simulation.rampDuration()), @@ -52,9 +59,5 @@ public static OpenInjectionStep[] setupModel(){ atOnceUsers(SimulationConfig.simulation.domainSetUpRumpUp()) }; } - public static OpenInjectionStep[] getStabilityOpenProfile() { - return new OpenInjectionStep[]{ - constantUsersPerSec(SimulationConfig.simulation.intensity()).during(SimulationConfig.simulation.stageDuration()) - }; - } + } diff --git a/src/test/java/jp/co/soramitsu/load/simulation/transaction/PerformanceSimulation.java b/src/test/java/jp/co/soramitsu/load/simulation/transaction/PerformanceSimulation.java index 0140822..14cb230 100644 --- a/src/test/java/jp/co/soramitsu/load/simulation/transaction/PerformanceSimulation.java +++ b/src/test/java/jp/co/soramitsu/load/simulation/transaction/PerformanceSimulation.java @@ -8,7 +8,8 @@ public class PerformanceSimulation extends Simulation { { setUp( jp.co.soramitsu.load.SetUp.Companion.apply().injectOpen(OpenInjectionStep.atOnceUsers(1)) - .andThen(TransferAssets.Companion.apply().injectClosed(LoadProfiles.getMaxPerformanceClosedProfile())) + //.andThen(TransferAssets.Companion.apply().injectClosed(LoadProfiles.getMaxPerformanceClosedProfile())) + .andThen(TransferAssets.Companion.apply().injectOpen(LoadProfiles.getStabilityOpenProfile())) .andThen(CleanUp.Companion.apply().injectOpen(OpenInjectionStep.atOnceUsers(1))) ).protocols(Protocols.httpProtocol); }