blob: ef82dba8ec98078876e0e373538c0958b4084ea3 [file] [log] [blame]
// Copyright 2015 The Bazel Authors. All rights reserved.
//
// Licensed 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 com.google.devtools.build.lib.actions;
import static com.google.common.truth.Truth.assertThat;
import com.google.devtools.build.lib.util.StringUtilities;
import com.google.devtools.build.lib.vfs.util.FsApparatus;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.JUnit4;
/**
* Test for LocalHostResourceManagerLinux.
*/
@RunWith(JUnit4.class)
public class LocalHostResourceManagerLinuxTest {
private final FsApparatus scratch = FsApparatus.newNative();
@Test
public void testNonHyperthreadedMachine() throws Exception {
String cpuinfoContent =
StringUtilities.joinLines(
"processor\t: 0",
"vendor_id\t: GenuineIntel",
"cpu family\t: 15",
"model\t\t: 4",
"model name\t: Intel(R) Pentium(R) 4 CPU 3.40GHz",
"stepping\t: 10",
"cpu MHz\t\t: 3400.000",
"cache size\t: 2048 KB",
"fpu\t\t: yes",
"fpu_exception\t: yes",
"cpuid level\t: 5",
"wp\t\t: yes",
"flags\t\t: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca "
+ "cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm "
+ "syscall nx lm constant_tsc up pni monitor ds_cpl est cid cx16 "
+ "xtpr lahf_lm",
"bogomips\t: 6803.83",
"clflush size\t: 64",
"cache_alignment\t: 128",
"address sizes\t: 36 bits physical, 48 bits virtual",
"power management:");
String meminfoContent =
StringUtilities.joinLines(
"MemTotal: 3091732 kB",
"MemFree: 2167344 kB",
"Buffers: 60644 kB",
"Cached: 509940 kB",
"SwapCached: 0 kB",
"Active: 636892 kB",
"Inactive: 212760 kB",
"HighTotal: 0 kB",
"HighFree: 0 kB",
"LowTotal: 3091732 kB",
"LowFree: 2167344 kB",
"SwapTotal: 9124880 kB",
"SwapFree: 9124880 kB",
"Dirty: 0 kB",
"Writeback: 0 kB",
"AnonPages: 279028 kB",
"Mapped: 54404 kB",
"Slab: 42820 kB",
"PageTables: 5184 kB",
"NFS_Unstable: 0 kB",
"Bounce: 0 kB",
"CommitLimit: 10670744 kB",
"Committed_AS: 665840 kB",
"VmallocTotal: 34359738367 kB",
"VmallocUsed: 300484 kB",
"VmallocChunk: 34359437307 kB",
"HugePages_Total: 0",
"HugePages_Free: 0",
"HugePages_Rsvd: 0",
"Hugepagesize: 2048 kB");
String meminfoFile = scratch.file("test_meminfo_nonht", meminfoContent).getPathString();
assertThat(LocalHostResourceManagerLinux.getLogicalCpuCountHelper(cpuinfoContent)).isEqualTo(1);
// +/- 0.1MB
assertThat(LocalHostResourceManagerLinux.getMemoryInMbHelper(meminfoFile))
.isWithin(0.1)
.of(3091732 >> 10); // kibis to meibis
}
@Test
public void testHyperthreadedMachine() throws Exception {
String cpuinfoContent =
StringUtilities.joinLines(
"processor\t: 0",
"vendor_id\t: GenuineIntel",
"cpu family\t: 15",
"model\t\t: 4",
"model name\t: Intel(R) Pentium(R) 4 CPU 3.40GHz",
"stepping\t: 1",
"cpu MHz\t\t: 3400.245",
"cache size\t: 1024 KB",
"physical id\t: 0",
"siblings\t: 2",
"core id\t\t: 0",
"cpu cores\t: 1",
"fpu\t\t: yes",
"fpu_exception\t: yes",
"cpuid level\t: 5",
"wp\t\t: yes",
"flags\t\t: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge "
+ "mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm "
+ "syscall lm constant_tsc pni monitor ds_cpl cid cx16 xtpr",
"bogomips\t: 6806.31",
"clflush size\t: 64",
"cache_alignment\t: 128",
"address sizes\t: 36 bits physical, 48 bits virtual",
"power management:",
"",
"processor\t: 1",
"vendor_id\t: GenuineIntel",
"cpu family\t: 15",
"model\t\t: 4",
"model name\t: Intel(R) Pentium(R) 4 CPU 3.40GHz",
"stepping\t: 1",
"cpu MHz\t\t: 3400.245",
"cache size\t: 1024 KB",
"physical id\t: 0",
"siblings\t: 2",
"core id\t\t: 0",
"cpu cores\t: 1",
"fpu\t\t: yes",
"fpu_exception\t: yes",
"cpuid level\t: 5",
"wp\t\t: yes",
"flags\t\t: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge "
+ "mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm "
+ "syscall lm constant_tsc pni monitor ds_cpl cid cx16 xtpr",
"bogomips\t: 6800.76",
"clflush size\t: 64",
"cache_alignment\t: 128",
"address sizes\t: 36 bits physical, 48 bits virtual",
"power management:",
"");
String meminfoContent =
StringUtilities.joinLines(
"MemTotal: 3092004 kB",
"MemFree: 26124 kB",
"Buffers: 3836 kB",
"Cached: 52400 kB",
"SwapCached: 68204 kB",
"Active: 2281464 kB",
"Inactive: 260908 kB",
"HighTotal: 0 kB",
"HighFree: 0 kB",
"LowTotal: 3092004 kB",
"LowFree: 26124 kB",
"SwapTotal: 9124880 kB",
"SwapFree: 8264920 kB",
"Dirty: 616 kB",
"Writeback: 0 kB",
"AnonPages: 2466336 kB",
"Mapped: 37576 kB",
"Slab: 483004 kB",
"PageTables: 11912 kB",
"NFS_Unstable: 0 kB",
"Bounce: 0 kB",
"CommitLimit: 10670880 kB",
"Committed_AS: 3627984 kB",
"VmallocTotal: 34359738367 kB",
"VmallocUsed: 300460 kB",
"VmallocChunk: 34359437307 kB",
"HugePages_Total: 0",
"HugePages_Free: 0",
"HugePages_Rsvd: 0",
"Hugepagesize: 2048 kB");
String meminfoFile = scratch.file("test_meminfo_ht", meminfoContent).getPathString();
assertThat(LocalHostResourceManagerLinux.getLogicalCpuCountHelper(cpuinfoContent)).isEqualTo(2);
// +/- 0.1MB
assertThat(LocalHostResourceManagerLinux.getMemoryInMbHelper(meminfoFile))
.isWithin(0.1)
.of(3092004 >> 10); // kibis to meibis
}
@Test
public void testAMDMachine() throws Exception {
String cpuinfoContent =
StringUtilities.joinLines(
"processor\t: 0",
"vendor_id\t: AuthenticAMD",
"cpu family\t: 15",
"model\t\t: 65",
"model name\t: Dual-Core AMD Opteron(tm) Processor 8214 HE",
"stepping\t: 2",
"cpu MHz\t\t: 2200.000",
"cache size\t: 1024 KB",
"physical id\t: 0",
"siblings\t: 2",
"core id\t\t: 0",
"cpu cores\t: 2",
"fpu\t\t: yes",
"fpu_exception\t: yes",
"cpuid level\t: 1",
"wp\t\t: yes",
"flags\t\t: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr "
+ "pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall "
+ "nx mmxext fxsr_opt rdtscp lm 3dnowext 3dnow pni cx16 lahf_lm "
+ "cmp_legacy svm cr8_legacy",
"bogomips\t: 4425.84",
"TLB size\t: 1024 4K pages",
"clflush size\t: 64",
"cache_alignment\t: 64",
"address sizes\t: 40 bits physical, 48 bits virtual",
"power management: ts fid vid ttp tm stc",
"",
"processor\t: 1",
"vendor_id\t: AuthenticAMD",
"cpu family\t: 15",
"model\t\t: 65",
"model name\t: Dual-Core AMD Opteron(tm) Processor 8214 HE",
"stepping\t: 2",
"cpu MHz\t\t: 2200.000",
"cache size\t: 1024 KB",
"physical id\t: 0",
"siblings\t: 2",
"core id\t\t: 1",
"cpu cores\t: 2",
"fpu\t\t: yes",
"fpu_exception\t: yes",
"cpuid level\t: 1",
"wp\t\t: yes",
"flags\t\t: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr "
+ "pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall "
+ "nx mmxext fxsr_opt rdtscp lm 3dnowext 3dnow pni cx16 lahf_lm "
+ "cmp_legacy svm cr8_legacy",
"bogomips\t: 4460.61",
"TLB size\t: 1024 4K pages",
"clflush size\t: 64",
"cache_alignment\t: 64",
"address sizes\t: 40 bits physical, 48 bits virtual",
"power management: ts fid vid ttp tm stc",
"",
"processor\t: 2",
"vendor_id\t: AuthenticAMD",
"cpu family\t: 15",
"model\t\t: 65",
"model name\t: Dual-Core AMD Opteron(tm) Processor 8214 HE",
"stepping\t: 2",
"cpu MHz\t\t: 2200.000",
"cache size\t: 1024 KB",
"physical id\t: 1",
"siblings\t: 2",
"core id\t\t: 0",
"cpu cores\t: 2",
"fpu\t\t: yes",
"fpu_exception\t: yes",
"cpuid level\t: 1",
"wp\t\t: yes",
"flags\t\t: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr "
+ "pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall "
+ "nx mmxext fxsr_opt rdtscp lm 3dnowext 3dnow pni cx16 lahf_lm "
+ "cmp_legacy svm cr8_legacy",
"bogomips\t: 4420.45",
"TLB size\t: 1024 4K pages",
"clflush size\t: 64",
"cache_alignment\t: 64",
"address sizes\t: 40 bits physical, 48 bits virtual",
"power management: ts fid vid ttp tm stc",
"",
"processor\t: 3",
"vendor_id\t: AuthenticAMD",
"cpu family\t: 15",
"model\t\t: 65",
"model name\t: Dual-Core AMD Opteron(tm) Processor 8214 HE",
"stepping\t: 2",
"cpu MHz\t\t: 2200.000",
"cache size\t: 1024 KB",
"physical id\t: 1",
"siblings\t: 2",
"core id\t\t: 1",
"cpu cores\t: 2",
"fpu\t\t: yes",
"fpu_exception\t: yes",
"cpuid level\t: 1",
"wp\t\t: yes",
"flags\t\t: fpu vme de pse tsc msr pae mce cx8 apic sep mtrr "
+ "pge mca cmov pat pse36 clflush mmx fxsr sse sse2 ht syscall "
+ "nx mmxext fxsr_opt rdtscp lm 3dnowext 3dnow pni cx16 lahf_lm "
+ "cmp_legacy svm cr8_legacy",
"bogomips\t: 4460.39",
"TLB size\t: 1024 4K pages",
"clflush size\t: 64",
"cache_alignment\t: 64",
"address sizes\t: 40 bits physical, 48 bits virtual",
"power management: ts fid vid ttp tm stc",
"");
String meminfoContent =
StringUtilities.joinLines(
"MemTotal: 8223956 kB",
"MemFree: 3670396 kB",
"Buffers: 374068 kB",
"Cached: 3366980 kB",
"SwapCached: 0 kB",
"Active: 3275860 kB",
"Inactive: 737816 kB",
"HighTotal: 0 kB",
"HighFree: 0 kB",
"LowTotal: 8223956 kB",
"LowFree: 3670396 kB",
"SwapTotal: 6024332 kB",
"SwapFree: 6024332 kB",
"Dirty: 84 kB",
"Writeback: 0 kB",
"AnonPages: 272308 kB",
"Mapped: 62604 kB",
"Slab: 506140 kB",
"PageTables: 4608 kB",
"NFS_Unstable: 0 kB",
"Bounce: 0 kB",
"CommitLimit: 10136308 kB",
"Committed_AS: 600672 kB",
"VmallocTotal: 34359738367 kB",
"VmallocUsed: 299068 kB",
"VmallocChunk: 34359438843 kB",
"HugePages_Total: 0",
"HugePages_Free: 0",
"HugePages_Rsvd: 0",
"Hugepagesize: 2048 kB");
String meminfoFile = scratch.file("test_meminfo_amd", meminfoContent).getPathString();
assertThat(LocalHostResourceManagerLinux.getLogicalCpuCountHelper(cpuinfoContent)).isEqualTo(4);
// +/- 0.1MB
assertThat(LocalHostResourceManagerLinux.getMemoryInMbHelper(meminfoFile))
.isWithin(0.1)
.of(8223956 >> 10); // kibis to meibis
}
}