test_percent_inclusive Subroutine

public subroutine test_percent_inclusive()

Uses

  • proc~~test_percent_inclusive~~UsesGraph proc~test_percent_inclusive test_PercentageColumn::test_percent_inclusive iso_fortran_env iso_fortran_env proc~test_percent_inclusive->iso_fortran_env

Arguments

None

Calls

proc~~test_percent_inclusive~~CallsGraph proc~test_percent_inclusive test_PercentageColumn::test_percent_inclusive add_cycle add_cycle proc~test_percent_inclusive->add_cycle assertequal assertequal proc~test_percent_inclusive->assertequal at at proc~test_percent_inclusive->at none~add_child MAPL_MeterNode::MeterNode%add_child proc~test_percent_inclusive->none~add_child none~get_child~3 MAPL_MeterNode::MeterNode%get_child proc~test_percent_inclusive->none~get_child~3 none~get_meter MAPL_MeterNode::MeterNode%get_meter proc~test_percent_inclusive->none~get_meter none~get_rows~3 MAPL_PercentageColumn::PercentageColumn%get_rows proc~test_percent_inclusive->none~get_rows~3 none~find_child MAPL_MeterNode::MeterNode%find_child none~add_child->none~find_child none~get_depth MAPL_MeterNode::MeterNode%get_depth none~add_child->none~get_depth none~push_back~4 MAPL_MeterNodeVector::MeterNodeVector%push_back none~add_child->none~push_back~4 none~at~7 MAPL_MeterNodeVector::MeterNodeVector%at none~get_child~3->none~at~7 none~get_child~3->none~find_child none~get_rows~3->at get_rows get_rows none~get_rows~3->get_rows push_back push_back none~get_rows~3->push_back none~at_32~2 MAPL_MeterNodeVector::MeterNodeVector%at_32 none~at~7->none~at_32~2 none~find_child->none~at~7 none~capacity~4 MAPL_MeterNodeVector::MeterNodeVector%capacity none~push_back~4->none~capacity~4 none~resize~4 MAPL_MeterNodeVector::MeterNodeVector%resize none~push_back~4->none~resize~4 none~at_size_kind~2 MAPL_MeterNodeVector::MeterNodeVector%at_size_kind none~at_32~2->none~at_size_kind~2 none~resize_32~3 MAPL_MeterNodeVector::MeterNodeVector%resize_32 none~resize~4->none~resize_32~3

Source Code

   subroutine test_percent_inclusive()
      use, intrinsic :: iso_fortran_env, only: REAL64
      type (PercentageColumn) :: c
      type (MeterNode), target :: node
      class (AbstractMeterNode), pointer :: child
      class (AbstractMeter), pointer :: t
      type(UnlimitedVector) :: v
      integer :: i
      integer :: expected(2)
      class(*), allocatable :: q

      node = MeterNode('foo', AdvancedMeter(MpiTimerGauge()))
      t => node%get_meter()
      call t%add_cycle(10.0_REAL64)

      call node%add_child('a', AdvancedMeter(MpiTimerGauge()))
      child => node%get_child('a')
      t => child%get_meter()
      call t%add_cycle(5.0_REAL64)
      
      c = PercentageColumn(InclusiveColumn(),'MAX')

      v = c%get_rows(node)
      expected = [100.,50.]
      do i = 1, 2
         q = v%at(i)
         select type (q)
         type is (real(kind=REAL64))
            @assertEqual(expected(i), q)
         end select
      end do
      
   end subroutine test_percent_inclusive