From 80fe0e6a02fca8b0886040f0f7eca738d6826c7c Mon Sep 17 00:00:00 2001 From: Johannes Markert Date: Thu, 31 Aug 2023 13:07:07 +0200 Subject: [PATCH] Added @allocated test. --- test/test_t8code_2d.jl | 33 ++++++++++++++++++++------------- test/test_t8code_3d.jl | 8 ++++++++ 2 files changed, 28 insertions(+), 13 deletions(-) diff --git a/test/test_t8code_2d.jl b/test/test_t8code_2d.jl index a424c9df84b..4f222dcb336 100644 --- a/test/test_t8code_2d.jl +++ b/test/test_t8code_2d.jl @@ -13,20 +13,19 @@ isdir(outdir) && rm(outdir, recursive = true) mkdir(outdir) @testset "T8codeMesh2D" begin - @trixi_testset "test save_mesh_file" begin - @test_throws Exception begin - # Save mesh file support will be added in the future. The following - # lines of code are here for satisfying code coverage. - - # Create dummy mesh. - mesh = T8codeMesh((1, 1), polydeg = 1, - mapping = Trixi.coordinates2mapping((-1.0, -1.0), ( 1.0, 1.0)), - initial_refinement_level = 1) - - # This call throws an error. - Trixi.save_mesh_file(mesh, "dummy") - end + @test_throws Exception begin + # Save mesh file support will be added in the future. The following + # lines of code are here for satisfying code coverage. + + # Create dummy mesh. + mesh = T8codeMesh((1, 1), polydeg = 1, + mapping = Trixi.coordinates2mapping((-1.0, -1.0), (1.0, 1.0)), + initial_refinement_level = 1) + + # This call throws an error. + Trixi.save_mesh_file(mesh, "dummy") + end end @trixi_testset "elixir_advection_basic.jl" begin @@ -41,6 +40,14 @@ mkdir(outdir) "elixir_advection_nonconforming_flag.jl"), l2=[3.198940059144588e-5], linf=[0.00030636069494005547]) + # Ensure that we do not have excessive memory allocations + # (e.g., from type instabilities) + let + t = sol.t[end] + u_ode = sol.u[end] + du_ode = similar(u_ode) + @test (@allocated Trixi.rhs!(du_ode, u_ode, semi, t)) < 1000 + end end @trixi_testset "elixir_advection_unstructured_flag.jl" begin diff --git a/test/test_t8code_3d.jl b/test/test_t8code_3d.jl index 01fda989aa7..a45d34fc6ba 100644 --- a/test/test_t8code_3d.jl +++ b/test/test_t8code_3d.jl @@ -31,6 +31,14 @@ mkdir(outdir) @test_trixi_include(joinpath(EXAMPLES_DIR, "elixir_advection_nonconforming.jl"), l2=[0.00253595715323843], linf=[0.016486952252155795]) + # Ensure that we do not have excessive memory allocations + # (e.g., from type instabilities) + let + t = sol.t[end] + u_ode = sol.u[end] + du_ode = similar(u_ode) + @test (@allocated Trixi.rhs!(du_ode, u_ode, semi, t)) < 1000 + end end @trixi_testset "elixir_advection_amr.jl" begin