| /** |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you under the Apache License, Version 2.0 (the |
| * "License"); you may not use this file except in compliance |
| * with the License. You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package org.apache.hadoop.mapred; |
| |
| import org.junit.Test; |
| import static org.junit.Assert.*; |
| |
| public class TestTaskPerformanceSplits { |
| @Test |
| public void testPeriodStatsets() { |
| PeriodicStatsAccumulator cumulative = new CumulativePeriodicStats(8); |
| PeriodicStatsAccumulator status = new StatePeriodicStats(8); |
| |
| cumulative.extend(0.0D, 0); |
| cumulative.extend(0.4375D, 700); // 200 per octant |
| cumulative.extend(0.5625D, 1100); // 0.5 = 900 |
| cumulative.extend(0.625D, 1300); |
| cumulative.extend(1.0D, 7901); |
| |
| int total = 0; |
| int[] results = cumulative.getValues(); |
| |
| for (int i = 0; i < 8; ++i) { |
| System.err.println("segment i = " + results[i]); |
| } |
| |
| assertEquals("Bad interpolation in cumulative segment 0", 200, results[0]); |
| assertEquals("Bad interpolation in cumulative segment 1", 200, results[1]); |
| assertEquals("Bad interpolation in cumulative segment 2", 200, results[2]); |
| assertEquals("Bad interpolation in cumulative segment 3", 300, results[3]); |
| assertEquals("Bad interpolation in cumulative segment 4", 400, results[4]); |
| assertEquals("Bad interpolation in cumulative segment 5", 2200, results[5]); |
| // these are rounded down |
| assertEquals("Bad interpolation in cumulative segment 6", 2200, results[6]); |
| assertEquals("Bad interpolation in cumulative segment 7", 2201, results[7]); |
| |
| status.extend(0.0D, 0); |
| status.extend(1.0D/16.0D, 300); // + 75 for bucket 0 |
| status.extend(3.0D/16.0D, 700); // + 200 for 0, +300 for 1 |
| status.extend(7.0D/16.0D, 2300); // + 450 for 1, + 1500 for 2, + 1050 for 3 |
| status.extend(1.0D, 1400); // +1125 for 3, +2100 for 4, +1900 for 5, |
| ; // +1700 for 6, +1500 for 7 |
| |
| results = status.getValues(); |
| |
| assertEquals("Bad interpolation in status segment 0", 275, results[0]); |
| assertEquals("Bad interpolation in status segment 1", 750, results[1]); |
| assertEquals("Bad interpolation in status segment 2", 1500, results[2]); |
| assertEquals("Bad interpolation in status segment 3", 2175, results[3]); |
| assertEquals("Bad interpolation in status segment 4", 2100, results[4]); |
| assertEquals("Bad interpolation in status segment 5", 1900, results[5]); |
| assertEquals("Bad interpolation in status segment 6", 1700, results[6]); |
| assertEquals("Bad interpolation in status segment 7", 1500, results[7]); |
| } |
| } |