You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@mesos.apache.org by gi...@apache.org on 2017/10/09 22:21:36 UTC
[2/3] mesos-site git commit: Updated the website built from mesos
SHA: d79dd98.
http://git-wip-us.apache.org/repos/asf/mesos-site/blob/da92e0c8/content/api/latest/c++/src_2tests_2mesos_8hpp_source.html
----------------------------------------------------------------------
diff --git a/content/api/latest/c++/src_2tests_2mesos_8hpp_source.html b/content/api/latest/c++/src_2tests_2mesos_8hpp_source.html
index 0533d77..53478bd 100644
--- a/content/api/latest/c++/src_2tests_2mesos_8hpp_source.html
+++ b/content/api/latest/c++/src_2tests_2mesos_8hpp_source.html
@@ -994,1906 +994,1932 @@
<div class="line"><a name="l00940"></a><span class="lineno"> 940</span> </div>
<div class="line"><a name="l00941"></a><span class="lineno"> 941</span> <span class="comment">// Helper for creating a disk source with type `PATH`.</span></div>
<div class="line"><a name="l00942"></a><span class="lineno"> 942</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResource></div>
-<div class="line"><a name="l00943"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#aa0d1366aacde31899214eac9515d62d3"> 943</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> TResource::DiskInfo::Source <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#aa0d1366aacde31899214eac9515d62d3">createDiskSourcePath</a>(</div>
-<div class="line"><a name="l00944"></a><span class="lineno"> 944</span>  <span class="keyword">const</span> std::string& root)</div>
-<div class="line"><a name="l00945"></a><span class="lineno"> 945</span> {</div>
-<div class="line"><a name="l00946"></a><span class="lineno"> 946</span>  <span class="keyword">typename</span> TResource::DiskInfo::Source source;</div>
-<div class="line"><a name="l00947"></a><span class="lineno"> 947</span> </div>
-<div class="line"><a name="l00948"></a><span class="lineno"> 948</span>  source.set_type(TResource::DiskInfo::Source::PATH);</div>
-<div class="line"><a name="l00949"></a><span class="lineno"> 949</span>  source.mutable_path()->set_root(root);</div>
-<div class="line"><a name="l00950"></a><span class="lineno"> 950</span> </div>
-<div class="line"><a name="l00951"></a><span class="lineno"> 951</span>  <span class="keywordflow">return</span> source;</div>
-<div class="line"><a name="l00952"></a><span class="lineno"> 952</span> }</div>
-<div class="line"><a name="l00953"></a><span class="lineno"> 953</span> </div>
-<div class="line"><a name="l00954"></a><span class="lineno"> 954</span> </div>
-<div class="line"><a name="l00955"></a><span class="lineno"> 955</span> <span class="comment">// Helper for creating a disk source with type `MOUNT`.</span></div>
-<div class="line"><a name="l00956"></a><span class="lineno"> 956</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResource></div>
-<div class="line"><a name="l00957"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3573848ddf00e8d6309eb03c0646c9ce"> 957</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> TResource::DiskInfo::Source <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3573848ddf00e8d6309eb03c0646c9ce">createDiskSourceMount</a>(</div>
-<div class="line"><a name="l00958"></a><span class="lineno"> 958</span>  <span class="keyword">const</span> std::string& root)</div>
-<div class="line"><a name="l00959"></a><span class="lineno"> 959</span> {</div>
-<div class="line"><a name="l00960"></a><span class="lineno"> 960</span>  <span class="keyword">typename</span> TResource::DiskInfo::Source source;</div>
-<div class="line"><a name="l00961"></a><span class="lineno"> 961</span> </div>
-<div class="line"><a name="l00962"></a><span class="lineno"> 962</span>  source.set_type(TResource::DiskInfo::Source::MOUNT);</div>
-<div class="line"><a name="l00963"></a><span class="lineno"> 963</span>  source.mutable_mount()->set_root(root);</div>
-<div class="line"><a name="l00964"></a><span class="lineno"> 964</span> </div>
-<div class="line"><a name="l00965"></a><span class="lineno"> 965</span>  <span class="keywordflow">return</span> source;</div>
-<div class="line"><a name="l00966"></a><span class="lineno"> 966</span> }</div>
+<div class="line"><a name="l00943"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3e0a121f23f7e53ba4fee14bc85c2093"> 943</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> TResource::DiskInfo::Source <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3e0a121f23f7e53ba4fee14bc85c2093">createDiskSourcePath</a>(</div>
+<div class="line"><a name="l00944"></a><span class="lineno"> 944</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& root,</div>
+<div class="line"><a name="l00945"></a><span class="lineno"> 945</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& <span class="keywordtype">id</span> = <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l00946"></a><span class="lineno"> 946</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& profile = <a class="code" href="structNone.html">None</a>())</div>
+<div class="line"><a name="l00947"></a><span class="lineno"> 947</span> {</div>
+<div class="line"><a name="l00948"></a><span class="lineno"> 948</span>  <span class="keyword">typename</span> TResource::DiskInfo::Source source;</div>
+<div class="line"><a name="l00949"></a><span class="lineno"> 949</span> </div>
+<div class="line"><a name="l00950"></a><span class="lineno"> 950</span>  source.set_type(TResource::DiskInfo::Source::PATH);</div>
+<div class="line"><a name="l00951"></a><span class="lineno"> 951</span> </div>
+<div class="line"><a name="l00952"></a><span class="lineno"> 952</span>  <span class="keywordflow">if</span> (root.<a class="code" href="classOption.html#a4e3bf8416d95246f43c91f1b5c309323">isSome</a>()) {</div>
+<div class="line"><a name="l00953"></a><span class="lineno"> 953</span>  source.mutable_path()->set_root(root.<a class="code" href="classOption.html#a21358442c0fac1cc978a67a9a9089a79">get</a>());</div>
+<div class="line"><a name="l00954"></a><span class="lineno"> 954</span>  }</div>
+<div class="line"><a name="l00955"></a><span class="lineno"> 955</span> </div>
+<div class="line"><a name="l00956"></a><span class="lineno"> 956</span>  <span class="keywordflow">if</span> (<span class="keywordtype">id</span>.isSome()) {</div>
+<div class="line"><a name="l00957"></a><span class="lineno"> 957</span>  source.set_id(<span class="keywordtype">id</span>.<span class="keyword">get</span>());</div>
+<div class="line"><a name="l00958"></a><span class="lineno"> 958</span>  }</div>
+<div class="line"><a name="l00959"></a><span class="lineno"> 959</span> </div>
+<div class="line"><a name="l00960"></a><span class="lineno"> 960</span>  <span class="keywordflow">if</span> (profile.isSome()) {</div>
+<div class="line"><a name="l00961"></a><span class="lineno"> 961</span>  source.set_profile(profile.get());</div>
+<div class="line"><a name="l00962"></a><span class="lineno"> 962</span>  }</div>
+<div class="line"><a name="l00963"></a><span class="lineno"> 963</span> </div>
+<div class="line"><a name="l00964"></a><span class="lineno"> 964</span>  <span class="keywordflow">return</span> source;</div>
+<div class="line"><a name="l00965"></a><span class="lineno"> 965</span> }</div>
+<div class="line"><a name="l00966"></a><span class="lineno"> 966</span> </div>
<div class="line"><a name="l00967"></a><span class="lineno"> 967</span> </div>
-<div class="line"><a name="l00968"></a><span class="lineno"> 968</span> </div>
-<div class="line"><a name="l00969"></a><span class="lineno"> 969</span> <span class="comment">// Helper for creating a disk resource.</span></div>
-<div class="line"><a name="l00970"></a><span class="lineno"> 970</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResource, <span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TVolume></div>
-<div class="line"><a name="l00971"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab1479066681bb142e54688ccae08c3a0"> 971</a></span> <span class="keyword">inline</span> TResource <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab1479066681bb142e54688ccae08c3a0">createDiskResource</a>(</div>
-<div class="line"><a name="l00972"></a><span class="lineno"> 972</span>  <span class="keyword">const</span> std::string& value,</div>
-<div class="line"><a name="l00973"></a><span class="lineno"> 973</span>  <span class="keyword">const</span> std::string& role,</div>
-<div class="line"><a name="l00974"></a><span class="lineno"> 974</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& persistenceID,</div>
-<div class="line"><a name="l00975"></a><span class="lineno"> 975</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& containerPath,</div>
-<div class="line"><a name="l00976"></a><span class="lineno"> 976</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<typename TResource::DiskInfo::Source></a>& source = <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l00977"></a><span class="lineno"> 977</span>  <span class="keywordtype">bool</span> isShared = <span class="keyword">false</span>)</div>
-<div class="line"><a name="l00978"></a><span class="lineno"> 978</span> {</div>
-<div class="line"><a name="l00979"></a><span class="lineno"> 979</span>  TResource resource = <a class="code" href="namespaceappc_1_1spec.html#a2107ae129dd83fbd20b22195247f16b5">TResources::parse</a>(<span class="stringliteral">"disk"</span>, value, role).get();</div>
-<div class="line"><a name="l00980"></a><span class="lineno"> 980</span> </div>
-<div class="line"><a name="l00981"></a><span class="lineno"> 981</span>  <span class="keywordflow">if</span> (persistenceID.<a class="code" href="classOption.html#a4e3bf8416d95246f43c91f1b5c309323">isSome</a>() || containerPath.<a class="code" href="classOption.html#a4e3bf8416d95246f43c91f1b5c309323">isSome</a>() || source.isSome()) {</div>
-<div class="line"><a name="l00982"></a><span class="lineno"> 982</span>  resource.mutable_disk()->CopyFrom(</div>
-<div class="line"><a name="l00983"></a><span class="lineno"> 983</span>  createDiskInfo<TResource, TVolume>(</div>
-<div class="line"><a name="l00984"></a><span class="lineno"> 984</span>  persistenceID,</div>
-<div class="line"><a name="l00985"></a><span class="lineno"> 985</span>  containerPath,</div>
-<div class="line"><a name="l00986"></a><span class="lineno"> 986</span>  <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l00987"></a><span class="lineno"> 987</span>  <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l00988"></a><span class="lineno"> 988</span>  source));</div>
-<div class="line"><a name="l00989"></a><span class="lineno"> 989</span> </div>
-<div class="line"><a name="l00990"></a><span class="lineno"> 990</span>  <span class="keywordflow">if</span> (isShared) {</div>
-<div class="line"><a name="l00991"></a><span class="lineno"> 991</span>  resource.mutable_shared();</div>
-<div class="line"><a name="l00992"></a><span class="lineno"> 992</span>  }</div>
-<div class="line"><a name="l00993"></a><span class="lineno"> 993</span>  }</div>
+<div class="line"><a name="l00968"></a><span class="lineno"> 968</span> <span class="comment">// Helper for creating a disk source with type `MOUNT`.</span></div>
+<div class="line"><a name="l00969"></a><span class="lineno"> 969</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResource></div>
+<div class="line"><a name="l00970"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#acf9334619820eae6a7f3618321e16229"> 970</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> TResource::DiskInfo::Source <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#acf9334619820eae6a7f3618321e16229">createDiskSourceMount</a>(</div>
+<div class="line"><a name="l00971"></a><span class="lineno"> 971</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& root,</div>
+<div class="line"><a name="l00972"></a><span class="lineno"> 972</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& <span class="keywordtype">id</span> = <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l00973"></a><span class="lineno"> 973</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& profile = <a class="code" href="structNone.html">None</a>())</div>
+<div class="line"><a name="l00974"></a><span class="lineno"> 974</span> {</div>
+<div class="line"><a name="l00975"></a><span class="lineno"> 975</span>  <span class="keyword">typename</span> TResource::DiskInfo::Source source;</div>
+<div class="line"><a name="l00976"></a><span class="lineno"> 976</span> </div>
+<div class="line"><a name="l00977"></a><span class="lineno"> 977</span>  source.set_type(TResource::DiskInfo::Source::MOUNT);</div>
+<div class="line"><a name="l00978"></a><span class="lineno"> 978</span> </div>
+<div class="line"><a name="l00979"></a><span class="lineno"> 979</span>  <span class="keywordflow">if</span> (root.<a class="code" href="classOption.html#a4e3bf8416d95246f43c91f1b5c309323">isSome</a>()) {</div>
+<div class="line"><a name="l00980"></a><span class="lineno"> 980</span>  source.mutable_mount()->set_root(root.<a class="code" href="classOption.html#a21358442c0fac1cc978a67a9a9089a79">get</a>());</div>
+<div class="line"><a name="l00981"></a><span class="lineno"> 981</span>  }</div>
+<div class="line"><a name="l00982"></a><span class="lineno"> 982</span> </div>
+<div class="line"><a name="l00983"></a><span class="lineno"> 983</span>  <span class="keywordflow">if</span> (<span class="keywordtype">id</span>.isSome()) {</div>
+<div class="line"><a name="l00984"></a><span class="lineno"> 984</span>  source.set_id(<span class="keywordtype">id</span>.<span class="keyword">get</span>());</div>
+<div class="line"><a name="l00985"></a><span class="lineno"> 985</span>  }</div>
+<div class="line"><a name="l00986"></a><span class="lineno"> 986</span> </div>
+<div class="line"><a name="l00987"></a><span class="lineno"> 987</span>  <span class="keywordflow">if</span> (profile.isSome()) {</div>
+<div class="line"><a name="l00988"></a><span class="lineno"> 988</span>  source.set_profile(profile.get());</div>
+<div class="line"><a name="l00989"></a><span class="lineno"> 989</span>  }</div>
+<div class="line"><a name="l00990"></a><span class="lineno"> 990</span> </div>
+<div class="line"><a name="l00991"></a><span class="lineno"> 991</span>  <span class="keywordflow">return</span> source;</div>
+<div class="line"><a name="l00992"></a><span class="lineno"> 992</span> }</div>
+<div class="line"><a name="l00993"></a><span class="lineno"> 993</span> </div>
<div class="line"><a name="l00994"></a><span class="lineno"> 994</span> </div>
-<div class="line"><a name="l00995"></a><span class="lineno"> 995</span>  <span class="keywordflow">return</span> resource;</div>
-<div class="line"><a name="l00996"></a><span class="lineno"> 996</span> }</div>
-<div class="line"><a name="l00997"></a><span class="lineno"> 997</span> </div>
-<div class="line"><a name="l00998"></a><span class="lineno"> 998</span> </div>
-<div class="line"><a name="l00999"></a><span class="lineno"> 999</span> <span class="comment">// Note that `reservationPrincipal` should be specified if and only if</span></div>
-<div class="line"><a name="l01000"></a><span class="lineno"> 1000</span> <span class="comment">// the volume uses dynamically reserved resources.</span></div>
-<div class="line"><a name="l01001"></a><span class="lineno"> 1001</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResource, <span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TVolume></div>
-<div class="line"><a name="l01002"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab3f6f80401c5645318402940ca2121ce"> 1002</a></span> <span class="keyword">inline</span> TResource <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab3f6f80401c5645318402940ca2121ce">createPersistentVolume</a>(</div>
-<div class="line"><a name="l01003"></a><span class="lineno"> 1003</span>  <span class="keyword">const</span> <a class="code" href="classBytes.html">Bytes</a>& <a class="code" href="namespaceos_1_1stat.html#a7a116891923bc8b5d8c50f78da8657be">size</a>,</div>
-<div class="line"><a name="l01004"></a><span class="lineno"> 1004</span>  <span class="keyword">const</span> std::string& role,</div>
-<div class="line"><a name="l01005"></a><span class="lineno"> 1005</span>  <span class="keyword">const</span> std::string& persistenceId,</div>
-<div class="line"><a name="l01006"></a><span class="lineno"> 1006</span>  <span class="keyword">const</span> std::string& containerPath,</div>
-<div class="line"><a name="l01007"></a><span class="lineno"> 1007</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& reservationPrincipal = <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l01008"></a><span class="lineno"> 1008</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<typename TResource::DiskInfo::Source></a>& source = <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l01009"></a><span class="lineno"> 1009</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& creatorPrincipal = <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l01010"></a><span class="lineno"> 1010</span>  <span class="keywordtype">bool</span> isShared = <span class="keyword">false</span>)</div>
-<div class="line"><a name="l01011"></a><span class="lineno"> 1011</span> {</div>
-<div class="line"><a name="l01012"></a><span class="lineno"> 1012</span>  TResource volume =</div>
-<div class="line"><a name="l01013"></a><span class="lineno"> 1013</span>  <a class="code" href="namespaceappc_1_1spec.html#a2107ae129dd83fbd20b22195247f16b5">TResources::parse</a>(<span class="stringliteral">"disk"</span>, <a class="code" href="namespacens.html#a28116b46e6543597a11733424cd1aa20">stringify</a>(size.<a class="code" href="classBytes.html#aee1957960ddcf609db170b0590ff7db5">megabytes</a>()), role).get();</div>
-<div class="line"><a name="l01014"></a><span class="lineno"> 1014</span> </div>
-<div class="line"><a name="l01015"></a><span class="lineno"> 1015</span>  volume.mutable_disk()->CopyFrom(</div>
-<div class="line"><a name="l01016"></a><span class="lineno"> 1016</span>  createDiskInfo<TResource, TVolume>(</div>
-<div class="line"><a name="l01017"></a><span class="lineno"> 1017</span>  persistenceId,</div>
-<div class="line"><a name="l01018"></a><span class="lineno"> 1018</span>  containerPath,</div>
-<div class="line"><a name="l01019"></a><span class="lineno"> 1019</span>  <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l01020"></a><span class="lineno"> 1020</span>  <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l01021"></a><span class="lineno"> 1021</span>  source,</div>
-<div class="line"><a name="l01022"></a><span class="lineno"> 1022</span>  creatorPrincipal));</div>
+<div class="line"><a name="l00995"></a><span class="lineno"> 995</span> <span class="comment">// Helper for creating a disk resource.</span></div>
+<div class="line"><a name="l00996"></a><span class="lineno"> 996</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResource, <span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TVolume></div>
+<div class="line"><a name="l00997"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab1479066681bb142e54688ccae08c3a0"> 997</a></span> <span class="keyword">inline</span> TResource <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab1479066681bb142e54688ccae08c3a0">createDiskResource</a>(</div>
+<div class="line"><a name="l00998"></a><span class="lineno"> 998</span>  <span class="keyword">const</span> std::string& value,</div>
+<div class="line"><a name="l00999"></a><span class="lineno"> 999</span>  <span class="keyword">const</span> std::string& role,</div>
+<div class="line"><a name="l01000"></a><span class="lineno"> 1000</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& persistenceID,</div>
+<div class="line"><a name="l01001"></a><span class="lineno"> 1001</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& containerPath,</div>
+<div class="line"><a name="l01002"></a><span class="lineno"> 1002</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<typename TResource::DiskInfo::Source></a>& source = <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01003"></a><span class="lineno"> 1003</span>  <span class="keywordtype">bool</span> isShared = <span class="keyword">false</span>)</div>
+<div class="line"><a name="l01004"></a><span class="lineno"> 1004</span> {</div>
+<div class="line"><a name="l01005"></a><span class="lineno"> 1005</span>  TResource resource = <a class="code" href="namespaceappc_1_1spec.html#a2107ae129dd83fbd20b22195247f16b5">TResources::parse</a>(<span class="stringliteral">"disk"</span>, value, role).get();</div>
+<div class="line"><a name="l01006"></a><span class="lineno"> 1006</span> </div>
+<div class="line"><a name="l01007"></a><span class="lineno"> 1007</span>  <span class="keywordflow">if</span> (persistenceID.<a class="code" href="classOption.html#a4e3bf8416d95246f43c91f1b5c309323">isSome</a>() || containerPath.<a class="code" href="classOption.html#a4e3bf8416d95246f43c91f1b5c309323">isSome</a>() || source.isSome()) {</div>
+<div class="line"><a name="l01008"></a><span class="lineno"> 1008</span>  resource.mutable_disk()->CopyFrom(</div>
+<div class="line"><a name="l01009"></a><span class="lineno"> 1009</span>  createDiskInfo<TResource, TVolume>(</div>
+<div class="line"><a name="l01010"></a><span class="lineno"> 1010</span>  persistenceID,</div>
+<div class="line"><a name="l01011"></a><span class="lineno"> 1011</span>  containerPath,</div>
+<div class="line"><a name="l01012"></a><span class="lineno"> 1012</span>  <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01013"></a><span class="lineno"> 1013</span>  <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01014"></a><span class="lineno"> 1014</span>  source));</div>
+<div class="line"><a name="l01015"></a><span class="lineno"> 1015</span> </div>
+<div class="line"><a name="l01016"></a><span class="lineno"> 1016</span>  <span class="keywordflow">if</span> (isShared) {</div>
+<div class="line"><a name="l01017"></a><span class="lineno"> 1017</span>  resource.mutable_shared();</div>
+<div class="line"><a name="l01018"></a><span class="lineno"> 1018</span>  }</div>
+<div class="line"><a name="l01019"></a><span class="lineno"> 1019</span>  }</div>
+<div class="line"><a name="l01020"></a><span class="lineno"> 1020</span> </div>
+<div class="line"><a name="l01021"></a><span class="lineno"> 1021</span>  <span class="keywordflow">return</span> resource;</div>
+<div class="line"><a name="l01022"></a><span class="lineno"> 1022</span> }</div>
<div class="line"><a name="l01023"></a><span class="lineno"> 1023</span> </div>
-<div class="line"><a name="l01024"></a><span class="lineno"> 1024</span>  <span class="keywordflow">if</span> (reservationPrincipal.isSome()) {</div>
-<div class="line"><a name="l01025"></a><span class="lineno"> 1025</span>  <span class="keyword">typename</span> TResource::ReservationInfo& reservation =</div>
-<div class="line"><a name="l01026"></a><span class="lineno"> 1026</span>  *volume.mutable_reservations()->rbegin();</div>
-<div class="line"><a name="l01027"></a><span class="lineno"> 1027</span> </div>
-<div class="line"><a name="l01028"></a><span class="lineno"> 1028</span>  reservation.set_type(TResource::ReservationInfo::DYNAMIC);</div>
-<div class="line"><a name="l01029"></a><span class="lineno"> 1029</span>  reservation.set_principal(reservationPrincipal.get());</div>
-<div class="line"><a name="l01030"></a><span class="lineno"> 1030</span>  }</div>
-<div class="line"><a name="l01031"></a><span class="lineno"> 1031</span> </div>
-<div class="line"><a name="l01032"></a><span class="lineno"> 1032</span>  <span class="keywordflow">if</span> (isShared) {</div>
-<div class="line"><a name="l01033"></a><span class="lineno"> 1033</span>  volume.mutable_shared();</div>
-<div class="line"><a name="l01034"></a><span class="lineno"> 1034</span>  }</div>
-<div class="line"><a name="l01035"></a><span class="lineno"> 1035</span> </div>
-<div class="line"><a name="l01036"></a><span class="lineno"> 1036</span>  <span class="keywordflow">return</span> volume;</div>
-<div class="line"><a name="l01037"></a><span class="lineno"> 1037</span> }</div>
-<div class="line"><a name="l01038"></a><span class="lineno"> 1038</span> </div>
-<div class="line"><a name="l01039"></a><span class="lineno"> 1039</span> </div>
-<div class="line"><a name="l01040"></a><span class="lineno"> 1040</span> <span class="comment">// Note that `reservationPrincipal` should be specified if and only if</span></div>
-<div class="line"><a name="l01041"></a><span class="lineno"> 1041</span> <span class="comment">// the volume uses dynamically reserved resources.</span></div>
-<div class="line"><a name="l01042"></a><span class="lineno"> 1042</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResource, <span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TVolume></div>
-<div class="line"><a name="l01043"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#afd8335a177e8bfe417b4668da9e161ac"> 1043</a></span> <span class="keyword">inline</span> TResource <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab3f6f80401c5645318402940ca2121ce">createPersistentVolume</a>(</div>
-<div class="line"><a name="l01044"></a><span class="lineno"> 1044</span>  TResource volume,</div>
-<div class="line"><a name="l01045"></a><span class="lineno"> 1045</span>  <span class="keyword">const</span> std::string& persistenceId,</div>
-<div class="line"><a name="l01046"></a><span class="lineno"> 1046</span>  <span class="keyword">const</span> std::string& containerPath,</div>
-<div class="line"><a name="l01047"></a><span class="lineno"> 1047</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& reservationPrincipal = <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l01048"></a><span class="lineno"> 1048</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& creatorPrincipal = <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l01049"></a><span class="lineno"> 1049</span>  <span class="keywordtype">bool</span> isShared = <span class="keyword">false</span>)</div>
-<div class="line"><a name="l01050"></a><span class="lineno"> 1050</span> {</div>
-<div class="line"><a name="l01051"></a><span class="lineno"> 1051</span>  <a class="code" href="classOption.html">Option<typename TResource::DiskInfo::Source></a> source = <a class="code" href="structNone.html">None</a>();</div>
-<div class="line"><a name="l01052"></a><span class="lineno"> 1052</span>  <span class="keywordflow">if</span> (volume.has_disk() && volume.disk().has_source()) {</div>
-<div class="line"><a name="l01053"></a><span class="lineno"> 1053</span>  source = volume.disk().source();</div>
-<div class="line"><a name="l01054"></a><span class="lineno"> 1054</span>  }</div>
-<div class="line"><a name="l01055"></a><span class="lineno"> 1055</span> </div>
-<div class="line"><a name="l01056"></a><span class="lineno"> 1056</span>  volume.mutable_disk()->CopyFrom(</div>
-<div class="line"><a name="l01057"></a><span class="lineno"> 1057</span>  createDiskInfo<TResource, TVolume>(</div>
-<div class="line"><a name="l01058"></a><span class="lineno"> 1058</span>  persistenceId,</div>
-<div class="line"><a name="l01059"></a><span class="lineno"> 1059</span>  containerPath,</div>
-<div class="line"><a name="l01060"></a><span class="lineno"> 1060</span>  <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l01061"></a><span class="lineno"> 1061</span>  <a class="code" href="structNone.html">None</a>(),</div>
-<div class="line"><a name="l01062"></a><span class="lineno"> 1062</span>  source,</div>
-<div class="line"><a name="l01063"></a><span class="lineno"> 1063</span>  creatorPrincipal));</div>
+<div class="line"><a name="l01024"></a><span class="lineno"> 1024</span> </div>
+<div class="line"><a name="l01025"></a><span class="lineno"> 1025</span> <span class="comment">// Note that `reservationPrincipal` should be specified if and only if</span></div>
+<div class="line"><a name="l01026"></a><span class="lineno"> 1026</span> <span class="comment">// the volume uses dynamically reserved resources.</span></div>
+<div class="line"><a name="l01027"></a><span class="lineno"> 1027</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResource, <span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TVolume></div>
+<div class="line"><a name="l01028"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab3f6f80401c5645318402940ca2121ce"> 1028</a></span> <span class="keyword">inline</span> TResource <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab3f6f80401c5645318402940ca2121ce">createPersistentVolume</a>(</div>
+<div class="line"><a name="l01029"></a><span class="lineno"> 1029</span>  <span class="keyword">const</span> <a class="code" href="classBytes.html">Bytes</a>& <a class="code" href="namespaceos_1_1stat.html#a7a116891923bc8b5d8c50f78da8657be">size</a>,</div>
+<div class="line"><a name="l01030"></a><span class="lineno"> 1030</span>  <span class="keyword">const</span> std::string& role,</div>
+<div class="line"><a name="l01031"></a><span class="lineno"> 1031</span>  <span class="keyword">const</span> std::string& persistenceId,</div>
+<div class="line"><a name="l01032"></a><span class="lineno"> 1032</span>  <span class="keyword">const</span> std::string& containerPath,</div>
+<div class="line"><a name="l01033"></a><span class="lineno"> 1033</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& reservationPrincipal = <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01034"></a><span class="lineno"> 1034</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<typename TResource::DiskInfo::Source></a>& source = <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01035"></a><span class="lineno"> 1035</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& creatorPrincipal = <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01036"></a><span class="lineno"> 1036</span>  <span class="keywordtype">bool</span> isShared = <span class="keyword">false</span>)</div>
+<div class="line"><a name="l01037"></a><span class="lineno"> 1037</span> {</div>
+<div class="line"><a name="l01038"></a><span class="lineno"> 1038</span>  TResource volume =</div>
+<div class="line"><a name="l01039"></a><span class="lineno"> 1039</span>  <a class="code" href="namespaceappc_1_1spec.html#a2107ae129dd83fbd20b22195247f16b5">TResources::parse</a>(<span class="stringliteral">"disk"</span>, <a class="code" href="namespacens.html#a28116b46e6543597a11733424cd1aa20">stringify</a>(size.<a class="code" href="classBytes.html#aee1957960ddcf609db170b0590ff7db5">megabytes</a>()), role).get();</div>
+<div class="line"><a name="l01040"></a><span class="lineno"> 1040</span> </div>
+<div class="line"><a name="l01041"></a><span class="lineno"> 1041</span>  volume.mutable_disk()->CopyFrom(</div>
+<div class="line"><a name="l01042"></a><span class="lineno"> 1042</span>  createDiskInfo<TResource, TVolume>(</div>
+<div class="line"><a name="l01043"></a><span class="lineno"> 1043</span>  persistenceId,</div>
+<div class="line"><a name="l01044"></a><span class="lineno"> 1044</span>  containerPath,</div>
+<div class="line"><a name="l01045"></a><span class="lineno"> 1045</span>  <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01046"></a><span class="lineno"> 1046</span>  <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01047"></a><span class="lineno"> 1047</span>  source,</div>
+<div class="line"><a name="l01048"></a><span class="lineno"> 1048</span>  creatorPrincipal));</div>
+<div class="line"><a name="l01049"></a><span class="lineno"> 1049</span> </div>
+<div class="line"><a name="l01050"></a><span class="lineno"> 1050</span>  <span class="keywordflow">if</span> (reservationPrincipal.isSome()) {</div>
+<div class="line"><a name="l01051"></a><span class="lineno"> 1051</span>  <span class="keyword">typename</span> TResource::ReservationInfo& reservation =</div>
+<div class="line"><a name="l01052"></a><span class="lineno"> 1052</span>  *volume.mutable_reservations()->rbegin();</div>
+<div class="line"><a name="l01053"></a><span class="lineno"> 1053</span> </div>
+<div class="line"><a name="l01054"></a><span class="lineno"> 1054</span>  reservation.set_type(TResource::ReservationInfo::DYNAMIC);</div>
+<div class="line"><a name="l01055"></a><span class="lineno"> 1055</span>  reservation.set_principal(reservationPrincipal.get());</div>
+<div class="line"><a name="l01056"></a><span class="lineno"> 1056</span>  }</div>
+<div class="line"><a name="l01057"></a><span class="lineno"> 1057</span> </div>
+<div class="line"><a name="l01058"></a><span class="lineno"> 1058</span>  <span class="keywordflow">if</span> (isShared) {</div>
+<div class="line"><a name="l01059"></a><span class="lineno"> 1059</span>  volume.mutable_shared();</div>
+<div class="line"><a name="l01060"></a><span class="lineno"> 1060</span>  }</div>
+<div class="line"><a name="l01061"></a><span class="lineno"> 1061</span> </div>
+<div class="line"><a name="l01062"></a><span class="lineno"> 1062</span>  <span class="keywordflow">return</span> volume;</div>
+<div class="line"><a name="l01063"></a><span class="lineno"> 1063</span> }</div>
<div class="line"><a name="l01064"></a><span class="lineno"> 1064</span> </div>
-<div class="line"><a name="l01065"></a><span class="lineno"> 1065</span>  <span class="keywordflow">if</span> (reservationPrincipal.isSome()) {</div>
-<div class="line"><a name="l01066"></a><span class="lineno"> 1066</span>  <span class="keyword">typename</span> TResource::ReservationInfo& reservation =</div>
-<div class="line"><a name="l01067"></a><span class="lineno"> 1067</span>  *volume.mutable_reservations()->rbegin();</div>
-<div class="line"><a name="l01068"></a><span class="lineno"> 1068</span> </div>
-<div class="line"><a name="l01069"></a><span class="lineno"> 1069</span>  reservation.set_type(TResource::ReservationInfo::DYNAMIC);</div>
-<div class="line"><a name="l01070"></a><span class="lineno"> 1070</span>  reservation.set_principal(reservationPrincipal.get());</div>
-<div class="line"><a name="l01071"></a><span class="lineno"> 1071</span>  }</div>
-<div class="line"><a name="l01072"></a><span class="lineno"> 1072</span> </div>
-<div class="line"><a name="l01073"></a><span class="lineno"> 1073</span>  <span class="keywordflow">if</span> (isShared) {</div>
-<div class="line"><a name="l01074"></a><span class="lineno"> 1074</span>  volume.mutable_shared();</div>
-<div class="line"><a name="l01075"></a><span class="lineno"> 1075</span>  }</div>
-<div class="line"><a name="l01076"></a><span class="lineno"> 1076</span> </div>
-<div class="line"><a name="l01077"></a><span class="lineno"> 1077</span>  <span class="keywordflow">return</span> volume;</div>
-<div class="line"><a name="l01078"></a><span class="lineno"> 1078</span> }</div>
-<div class="line"><a name="l01079"></a><span class="lineno"> 1079</span> </div>
-<div class="line"><a name="l01080"></a><span class="lineno"> 1080</span> </div>
-<div class="line"><a name="l01081"></a><span class="lineno"> 1081</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TCredential></div>
-<div class="line"><a name="l01082"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a33e1b9a2dea5527be8737ed6084567fb"> 1082</a></span> <span class="keyword">inline</span> <a class="code" href="classprocess_1_1http_1_1Headers.html">process::http::Headers</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a33e1b9a2dea5527be8737ed6084567fb">createBasicAuthHeaders</a>(</div>
-<div class="line"><a name="l01083"></a><span class="lineno"> 1083</span>  <span class="keyword">const</span> TCredential& credential)</div>
-<div class="line"><a name="l01084"></a><span class="lineno"> 1084</span> {</div>
-<div class="line"><a name="l01085"></a><span class="lineno"> 1085</span>  <span class="keywordflow">return</span> <a class="code" href="classprocess_1_1http_1_1Headers.html">process::http::Headers</a>({{</div>
-<div class="line"><a name="l01086"></a><span class="lineno"> 1086</span>  <span class="stringliteral">"Authorization"</span>,</div>
-<div class="line"><a name="l01087"></a><span class="lineno"> 1087</span>  <span class="stringliteral">"Basic "</span> +</div>
-<div class="line"><a name="l01088"></a><span class="lineno"> 1088</span>  <a class="code" href="namespacebase64.html#a47c61bb5df3dae8cd38f44b6b69e5b4d">base64::encode</a>(credential.principal() + <span class="stringliteral">":"</span> + credential.secret())</div>
-<div class="line"><a name="l01089"></a><span class="lineno"> 1089</span>  }});</div>
-<div class="line"><a name="l01090"></a><span class="lineno"> 1090</span> }</div>
-<div class="line"><a name="l01091"></a><span class="lineno"> 1091</span> </div>
-<div class="line"><a name="l01092"></a><span class="lineno"> 1092</span> </div>
-<div class="line"><a name="l01093"></a><span class="lineno"> 1093</span> <span class="comment">// Create WeightInfos from the specified weights flag.</span></div>
-<div class="line"><a name="l01094"></a><span class="lineno"> 1094</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TWeightInfo></div>
-<div class="line"><a name="l01095"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a96c6096bba99af5d2e8093b06f315c15"> 1095</a></span> <span class="keyword">inline</span> google::protobuf::RepeatedPtrField<TWeightInfo> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a96c6096bba99af5d2e8093b06f315c15">createWeightInfos</a>(</div>
-<div class="line"><a name="l01096"></a><span class="lineno"> 1096</span>  <span class="keyword">const</span> std::string& weightsFlag)</div>
-<div class="line"><a name="l01097"></a><span class="lineno"> 1097</span> {</div>
-<div class="line"><a name="l01098"></a><span class="lineno"> 1098</span>  google::protobuf::RepeatedPtrField<TWeightInfo> <a class="code" href="namespacerouting_1_1diagnosis_1_1socket.html#a8937277756951dcc28f2dbdbd9ea24d7">infos</a>;</div>
-<div class="line"><a name="l01099"></a><span class="lineno"> 1099</span>  std::vector<std::string> tokens = <a class="code" href="namespacestrings.html#afffe11c8ecce961981653358520d6a04">strings::tokenize</a>(weightsFlag, <span class="stringliteral">","</span>);</div>
-<div class="line"><a name="l01100"></a><span class="lineno"> 1100</span>  <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string& token, tokens) {</div>
-<div class="line"><a name="l01101"></a><span class="lineno"> 1101</span>  std::vector<std::string> pair = <a class="code" href="namespacestrings.html#afffe11c8ecce961981653358520d6a04">strings::tokenize</a>(token, <span class="stringliteral">"="</span>);</div>
-<div class="line"><a name="l01102"></a><span class="lineno"> 1102</span>  EXPECT_EQ(2u, pair.size());</div>
-<div class="line"><a name="l01103"></a><span class="lineno"> 1103</span>  <span class="keywordtype">double</span> weight = atof(pair[1].c_str());</div>
-<div class="line"><a name="l01104"></a><span class="lineno"> 1104</span>  TWeightInfo weightInfo;</div>
-<div class="line"><a name="l01105"></a><span class="lineno"> 1105</span>  weightInfo.set_role(pair[0]);</div>
-<div class="line"><a name="l01106"></a><span class="lineno"> 1106</span>  weightInfo.set_weight(weight);</div>
-<div class="line"><a name="l01107"></a><span class="lineno"> 1107</span>  infos.Add()->CopyFrom(weightInfo);</div>
-<div class="line"><a name="l01108"></a><span class="lineno"> 1108</span>  }</div>
-<div class="line"><a name="l01109"></a><span class="lineno"> 1109</span> </div>
-<div class="line"><a name="l01110"></a><span class="lineno"> 1110</span>  <span class="keywordflow">return</span> <a class="code" href="namespacerouting_1_1diagnosis_1_1socket.html#a8937277756951dcc28f2dbdbd9ea24d7">infos</a>;</div>
-<div class="line"><a name="l01111"></a><span class="lineno"> 1111</span> }</div>
-<div class="line"><a name="l01112"></a><span class="lineno"> 1112</span> </div>
-<div class="line"><a name="l01113"></a><span class="lineno"> 1113</span> </div>
-<div class="line"><a name="l01114"></a><span class="lineno"> 1114</span> <span class="comment">// Convert WeightInfos protobuf to weights hashmap.</span></div>
-<div class="line"><a name="l01115"></a><span class="lineno"> 1115</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TWeightInfo></div>
-<div class="line"><a name="l01116"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ac4a5499bf7bd860c85008cee8dec7582"> 1116</a></span> <span class="keyword">inline</span> <a class="code" href="classhashmap.html">hashmap<std::string, double></a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ac4a5499bf7bd860c85008cee8dec7582">convertToHashmap</a>(</div>
-<div class="line"><a name="l01117"></a><span class="lineno"> 1117</span>  <span class="keyword">const</span> google::protobuf::RepeatedPtrField<TWeightInfo> weightInfos)</div>
-<div class="line"><a name="l01118"></a><span class="lineno"> 1118</span> {</div>
-<div class="line"><a name="l01119"></a><span class="lineno"> 1119</span>  <a class="code" href="classhashmap.html">hashmap<std::string, double></a> weights;</div>
-<div class="line"><a name="l01120"></a><span class="lineno"> 1120</span> </div>
-<div class="line"><a name="l01121"></a><span class="lineno"> 1121</span>  <span class="keywordflow">foreach</span> (<span class="keyword">const</span> TWeightInfo& weightInfo, weightInfos) {</div>
-<div class="line"><a name="l01122"></a><span class="lineno"> 1122</span>  weights[weightInfo.role()] = weightInfo.weight();</div>
-<div class="line"><a name="l01123"></a><span class="lineno"> 1123</span>  }</div>
-<div class="line"><a name="l01124"></a><span class="lineno"> 1124</span> </div>
-<div class="line"><a name="l01125"></a><span class="lineno"> 1125</span>  <span class="keywordflow">return</span> weights;</div>
-<div class="line"><a name="l01126"></a><span class="lineno"> 1126</span> }</div>
-<div class="line"><a name="l01127"></a><span class="lineno"> 1127</span> </div>
-<div class="line"><a name="l01128"></a><span class="lineno"> 1128</span> </div>
-<div class="line"><a name="l01129"></a><span class="lineno"> 1129</span> <span class="comment">// Helper to create DomainInfo.</span></div>
-<div class="line"><a name="l01130"></a><span class="lineno"> 1130</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TDomainInfo></div>
-<div class="line"><a name="l01131"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a350e4f6f831f99d6a3b6f17cdc4f9765"> 1131</a></span> <span class="keyword">inline</span> TDomainInfo <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a350e4f6f831f99d6a3b6f17cdc4f9765">createDomainInfo</a>(</div>
-<div class="line"><a name="l01132"></a><span class="lineno"> 1132</span>  <span class="keyword">const</span> std::string& regionName,</div>
-<div class="line"><a name="l01133"></a><span class="lineno"> 1133</span>  <span class="keyword">const</span> std::string& zoneName)</div>
-<div class="line"><a name="l01134"></a><span class="lineno"> 1134</span> {</div>
-<div class="line"><a name="l01135"></a><span class="lineno"> 1135</span>  TDomainInfo domain;</div>
-<div class="line"><a name="l01136"></a><span class="lineno"> 1136</span> </div>
-<div class="line"><a name="l01137"></a><span class="lineno"> 1137</span>  domain.mutable_fault_domain()->mutable_region()->set_name(regionName);</div>
-<div class="line"><a name="l01138"></a><span class="lineno"> 1138</span>  domain.mutable_fault_domain()->mutable_zone()->set_name(zoneName);</div>
+<div class="line"><a name="l01065"></a><span class="lineno"> 1065</span> </div>
+<div class="line"><a name="l01066"></a><span class="lineno"> 1066</span> <span class="comment">// Note that `reservationPrincipal` should be specified if and only if</span></div>
+<div class="line"><a name="l01067"></a><span class="lineno"> 1067</span> <span class="comment">// the volume uses dynamically reserved resources.</span></div>
+<div class="line"><a name="l01068"></a><span class="lineno"> 1068</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResource, <span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TVolume></div>
+<div class="line"><a name="l01069"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#afd8335a177e8bfe417b4668da9e161ac"> 1069</a></span> <span class="keyword">inline</span> TResource <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ab3f6f80401c5645318402940ca2121ce">createPersistentVolume</a>(</div>
+<div class="line"><a name="l01070"></a><span class="lineno"> 1070</span>  TResource volume,</div>
+<div class="line"><a name="l01071"></a><span class="lineno"> 1071</span>  <span class="keyword">const</span> std::string& persistenceId,</div>
+<div class="line"><a name="l01072"></a><span class="lineno"> 1072</span>  <span class="keyword">const</span> std::string& containerPath,</div>
+<div class="line"><a name="l01073"></a><span class="lineno"> 1073</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& reservationPrincipal = <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01074"></a><span class="lineno"> 1074</span>  <span class="keyword">const</span> <a class="code" href="classOption.html">Option<std::string></a>& creatorPrincipal = <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01075"></a><span class="lineno"> 1075</span>  <span class="keywordtype">bool</span> isShared = <span class="keyword">false</span>)</div>
+<div class="line"><a name="l01076"></a><span class="lineno"> 1076</span> {</div>
+<div class="line"><a name="l01077"></a><span class="lineno"> 1077</span>  <a class="code" href="classOption.html">Option<typename TResource::DiskInfo::Source></a> source = <a class="code" href="structNone.html">None</a>();</div>
+<div class="line"><a name="l01078"></a><span class="lineno"> 1078</span>  <span class="keywordflow">if</span> (volume.has_disk() && volume.disk().has_source()) {</div>
+<div class="line"><a name="l01079"></a><span class="lineno"> 1079</span>  source = volume.disk().source();</div>
+<div class="line"><a name="l01080"></a><span class="lineno"> 1080</span>  }</div>
+<div class="line"><a name="l01081"></a><span class="lineno"> 1081</span> </div>
+<div class="line"><a name="l01082"></a><span class="lineno"> 1082</span>  volume.mutable_disk()->CopyFrom(</div>
+<div class="line"><a name="l01083"></a><span class="lineno"> 1083</span>  createDiskInfo<TResource, TVolume>(</div>
+<div class="line"><a name="l01084"></a><span class="lineno"> 1084</span>  persistenceId,</div>
+<div class="line"><a name="l01085"></a><span class="lineno"> 1085</span>  containerPath,</div>
+<div class="line"><a name="l01086"></a><span class="lineno"> 1086</span>  <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01087"></a><span class="lineno"> 1087</span>  <a class="code" href="structNone.html">None</a>(),</div>
+<div class="line"><a name="l01088"></a><span class="lineno"> 1088</span>  source,</div>
+<div class="line"><a name="l01089"></a><span class="lineno"> 1089</span>  creatorPrincipal));</div>
+<div class="line"><a name="l01090"></a><span class="lineno"> 1090</span> </div>
+<div class="line"><a name="l01091"></a><span class="lineno"> 1091</span>  <span class="keywordflow">if</span> (reservationPrincipal.isSome()) {</div>
+<div class="line"><a name="l01092"></a><span class="lineno"> 1092</span>  <span class="keyword">typename</span> TResource::ReservationInfo& reservation =</div>
+<div class="line"><a name="l01093"></a><span class="lineno"> 1093</span>  *volume.mutable_reservations()->rbegin();</div>
+<div class="line"><a name="l01094"></a><span class="lineno"> 1094</span> </div>
+<div class="line"><a name="l01095"></a><span class="lineno"> 1095</span>  reservation.set_type(TResource::ReservationInfo::DYNAMIC);</div>
+<div class="line"><a name="l01096"></a><span class="lineno"> 1096</span>  reservation.set_principal(reservationPrincipal.get());</div>
+<div class="line"><a name="l01097"></a><span class="lineno"> 1097</span>  }</div>
+<div class="line"><a name="l01098"></a><span class="lineno"> 1098</span> </div>
+<div class="line"><a name="l01099"></a><span class="lineno"> 1099</span>  <span class="keywordflow">if</span> (isShared) {</div>
+<div class="line"><a name="l01100"></a><span class="lineno"> 1100</span>  volume.mutable_shared();</div>
+<div class="line"><a name="l01101"></a><span class="lineno"> 1101</span>  }</div>
+<div class="line"><a name="l01102"></a><span class="lineno"> 1102</span> </div>
+<div class="line"><a name="l01103"></a><span class="lineno"> 1103</span>  <span class="keywordflow">return</span> volume;</div>
+<div class="line"><a name="l01104"></a><span class="lineno"> 1104</span> }</div>
+<div class="line"><a name="l01105"></a><span class="lineno"> 1105</span> </div>
+<div class="line"><a name="l01106"></a><span class="lineno"> 1106</span> </div>
+<div class="line"><a name="l01107"></a><span class="lineno"> 1107</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TCredential></div>
+<div class="line"><a name="l01108"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a33e1b9a2dea5527be8737ed6084567fb"> 1108</a></span> <span class="keyword">inline</span> <a class="code" href="classprocess_1_1http_1_1Headers.html">process::http::Headers</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a33e1b9a2dea5527be8737ed6084567fb">createBasicAuthHeaders</a>(</div>
+<div class="line"><a name="l01109"></a><span class="lineno"> 1109</span>  <span class="keyword">const</span> TCredential& credential)</div>
+<div class="line"><a name="l01110"></a><span class="lineno"> 1110</span> {</div>
+<div class="line"><a name="l01111"></a><span class="lineno"> 1111</span>  <span class="keywordflow">return</span> <a class="code" href="classprocess_1_1http_1_1Headers.html">process::http::Headers</a>({{</div>
+<div class="line"><a name="l01112"></a><span class="lineno"> 1112</span>  <span class="stringliteral">"Authorization"</span>,</div>
+<div class="line"><a name="l01113"></a><span class="lineno"> 1113</span>  <span class="stringliteral">"Basic "</span> +</div>
+<div class="line"><a name="l01114"></a><span class="lineno"> 1114</span>  <a class="code" href="namespacebase64.html#a47c61bb5df3dae8cd38f44b6b69e5b4d">base64::encode</a>(credential.principal() + <span class="stringliteral">":"</span> + credential.secret())</div>
+<div class="line"><a name="l01115"></a><span class="lineno"> 1115</span>  }});</div>
+<div class="line"><a name="l01116"></a><span class="lineno"> 1116</span> }</div>
+<div class="line"><a name="l01117"></a><span class="lineno"> 1117</span> </div>
+<div class="line"><a name="l01118"></a><span class="lineno"> 1118</span> </div>
+<div class="line"><a name="l01119"></a><span class="lineno"> 1119</span> <span class="comment">// Create WeightInfos from the specified weights flag.</span></div>
+<div class="line"><a name="l01120"></a><span class="lineno"> 1120</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TWeightInfo></div>
+<div class="line"><a name="l01121"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a96c6096bba99af5d2e8093b06f315c15"> 1121</a></span> <span class="keyword">inline</span> google::protobuf::RepeatedPtrField<TWeightInfo> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a96c6096bba99af5d2e8093b06f315c15">createWeightInfos</a>(</div>
+<div class="line"><a name="l01122"></a><span class="lineno"> 1122</span>  <span class="keyword">const</span> std::string& weightsFlag)</div>
+<div class="line"><a name="l01123"></a><span class="lineno"> 1123</span> {</div>
+<div class="line"><a name="l01124"></a><span class="lineno"> 1124</span>  google::protobuf::RepeatedPtrField<TWeightInfo> <a class="code" href="namespacerouting_1_1diagnosis_1_1socket.html#a8937277756951dcc28f2dbdbd9ea24d7">infos</a>;</div>
+<div class="line"><a name="l01125"></a><span class="lineno"> 1125</span>  std::vector<std::string> tokens = <a class="code" href="namespacestrings.html#afffe11c8ecce961981653358520d6a04">strings::tokenize</a>(weightsFlag, <span class="stringliteral">","</span>);</div>
+<div class="line"><a name="l01126"></a><span class="lineno"> 1126</span>  <span class="keywordflow">foreach</span> (<span class="keyword">const</span> std::string& token, tokens) {</div>
+<div class="line"><a name="l01127"></a><span class="lineno"> 1127</span>  std::vector<std::string> pair = <a class="code" href="namespacestrings.html#afffe11c8ecce961981653358520d6a04">strings::tokenize</a>(token, <span class="stringliteral">"="</span>);</div>
+<div class="line"><a name="l01128"></a><span class="lineno"> 1128</span>  EXPECT_EQ(2u, pair.size());</div>
+<div class="line"><a name="l01129"></a><span class="lineno"> 1129</span>  <span class="keywordtype">double</span> weight = atof(pair[1].c_str());</div>
+<div class="line"><a name="l01130"></a><span class="lineno"> 1130</span>  TWeightInfo weightInfo;</div>
+<div class="line"><a name="l01131"></a><span class="lineno"> 1131</span>  weightInfo.set_role(pair[0]);</div>
+<div class="line"><a name="l01132"></a><span class="lineno"> 1132</span>  weightInfo.set_weight(weight);</div>
+<div class="line"><a name="l01133"></a><span class="lineno"> 1133</span>  infos.Add()->CopyFrom(weightInfo);</div>
+<div class="line"><a name="l01134"></a><span class="lineno"> 1134</span>  }</div>
+<div class="line"><a name="l01135"></a><span class="lineno"> 1135</span> </div>
+<div class="line"><a name="l01136"></a><span class="lineno"> 1136</span>  <span class="keywordflow">return</span> <a class="code" href="namespacerouting_1_1diagnosis_1_1socket.html#a8937277756951dcc28f2dbdbd9ea24d7">infos</a>;</div>
+<div class="line"><a name="l01137"></a><span class="lineno"> 1137</span> }</div>
+<div class="line"><a name="l01138"></a><span class="lineno"> 1138</span> </div>
<div class="line"><a name="l01139"></a><span class="lineno"> 1139</span> </div>
-<div class="line"><a name="l01140"></a><span class="lineno"> 1140</span>  <span class="keywordflow">return</span> domain;</div>
-<div class="line"><a name="l01141"></a><span class="lineno"> 1141</span> }</div>
-<div class="line"><a name="l01142"></a><span class="lineno"> 1142</span> </div>
-<div class="line"><a name="l01143"></a><span class="lineno"> 1143</span> </div>
-<div class="line"><a name="l01144"></a><span class="lineno"> 1144</span> <span class="comment">// Helpers for creating offer operations.</span></div>
-<div class="line"><a name="l01145"></a><span class="lineno"> 1145</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TOffer></div>
-<div class="line"><a name="l01146"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a07ba9c332393ad463065495f37c5bced"> 1146</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a07ba9c332393ad463065495f37c5bced">RESERVE</a>(<span class="keyword">const</span> TResources& resources)</div>
-<div class="line"><a name="l01147"></a><span class="lineno"> 1147</span> {</div>
-<div class="line"><a name="l01148"></a><span class="lineno"> 1148</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
-<div class="line"><a name="l01149"></a><span class="lineno"> 1149</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a07ba9c332393ad463065495f37c5bced">TOffer::Operation::RESERVE</a>);</div>
-<div class="line"><a name="l01150"></a><span class="lineno"> 1150</span>  operation.mutable_reserve()->mutable_resources()->CopyFrom(resources);</div>
-<div class="line"><a name="l01151"></a><span class="lineno"> 1151</span>  <span class="keywordflow">return</span> operation;</div>
+<div class="line"><a name="l01140"></a><span class="lineno"> 1140</span> <span class="comment">// Convert WeightInfos protobuf to weights hashmap.</span></div>
+<div class="line"><a name="l01141"></a><span class="lineno"> 1141</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TWeightInfo></div>
+<div class="line"><a name="l01142"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ac4a5499bf7bd860c85008cee8dec7582"> 1142</a></span> <span class="keyword">inline</span> <a class="code" href="classhashmap.html">hashmap<std::string, double></a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ac4a5499bf7bd860c85008cee8dec7582">convertToHashmap</a>(</div>
+<div class="line"><a name="l01143"></a><span class="lineno"> 1143</span>  <span class="keyword">const</span> google::protobuf::RepeatedPtrField<TWeightInfo> weightInfos)</div>
+<div class="line"><a name="l01144"></a><span class="lineno"> 1144</span> {</div>
+<div class="line"><a name="l01145"></a><span class="lineno"> 1145</span>  <a class="code" href="classhashmap.html">hashmap<std::string, double></a> weights;</div>
+<div class="line"><a name="l01146"></a><span class="lineno"> 1146</span> </div>
+<div class="line"><a name="l01147"></a><span class="lineno"> 1147</span>  <span class="keywordflow">foreach</span> (<span class="keyword">const</span> TWeightInfo& weightInfo, weightInfos) {</div>
+<div class="line"><a name="l01148"></a><span class="lineno"> 1148</span>  weights[weightInfo.role()] = weightInfo.weight();</div>
+<div class="line"><a name="l01149"></a><span class="lineno"> 1149</span>  }</div>
+<div class="line"><a name="l01150"></a><span class="lineno"> 1150</span> </div>
+<div class="line"><a name="l01151"></a><span class="lineno"> 1151</span>  <span class="keywordflow">return</span> weights;</div>
<div class="line"><a name="l01152"></a><span class="lineno"> 1152</span> }</div>
<div class="line"><a name="l01153"></a><span class="lineno"> 1153</span> </div>
<div class="line"><a name="l01154"></a><span class="lineno"> 1154</span> </div>
-<div class="line"><a name="l01155"></a><span class="lineno"> 1155</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TOffer></div>
-<div class="line"><a name="l01156"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a7502aad15971920c0d5907ca2f010859"> 1156</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a7502aad15971920c0d5907ca2f010859">UNRESERVE</a>(<span class="keyword">const</span> TResources& resources)</div>
-<div class="line"><a name="l01157"></a><span class="lineno"> 1157</span> {</div>
-<div class="line"><a name="l01158"></a><span class="lineno"> 1158</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
-<div class="line"><a name="l01159"></a><span class="lineno"> 1159</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a7502aad15971920c0d5907ca2f010859">TOffer::Operation::UNRESERVE</a>);</div>
-<div class="line"><a name="l01160"></a><span class="lineno"> 1160</span>  operation.mutable_unreserve()->mutable_resources()->CopyFrom(resources);</div>
-<div class="line"><a name="l01161"></a><span class="lineno"> 1161</span>  <span class="keywordflow">return</span> operation;</div>
-<div class="line"><a name="l01162"></a><span class="lineno"> 1162</span> }</div>
-<div class="line"><a name="l01163"></a><span class="lineno"> 1163</span> </div>
-<div class="line"><a name="l01164"></a><span class="lineno"> 1164</span> </div>
-<div class="line"><a name="l01165"></a><span class="lineno"> 1165</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TOffer></div>
-<div class="line"><a name="l01166"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3fe53df8c99e8dce61568ce527030ce7"> 1166</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3fe53df8c99e8dce61568ce527030ce7">CREATE</a>(<span class="keyword">const</span> TResources& volumes)</div>
-<div class="line"><a name="l01167"></a><span class="lineno"> 1167</span> {</div>
-<div class="line"><a name="l01168"></a><span class="lineno"> 1168</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
-<div class="line"><a name="l01169"></a><span class="lineno"> 1169</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3fe53df8c99e8dce61568ce527030ce7">TOffer::Operation::CREATE</a>);</div>
-<div class="line"><a name="l01170"></a><span class="lineno"> 1170</span>  operation.mutable_create()->mutable_volumes()->CopyFrom(volumes);</div>
-<div class="line"><a name="l01171"></a><span class="lineno"> 1171</span>  <span class="keywordflow">return</span> operation;</div>
-<div class="line"><a name="l01172"></a><span class="lineno"> 1172</span> }</div>
-<div class="line"><a name="l01173"></a><span class="lineno"> 1173</span> </div>
-<div class="line"><a name="l01174"></a><span class="lineno"> 1174</span> </div>
-<div class="line"><a name="l01175"></a><span class="lineno"> 1175</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TOffer></div>
-<div class="line"><a name="l01176"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a8a7409ebbb940e352722588a8e0bb106"> 1176</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a8a7409ebbb940e352722588a8e0bb106">DESTROY</a>(<span class="keyword">const</span> TResources& volumes)</div>
-<div class="line"><a name="l01177"></a><span class="lineno"> 1177</span> {</div>
-<div class="line"><a name="l01178"></a><span class="lineno"> 1178</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
-<div class="line"><a name="l01179"></a><span class="lineno"> 1179</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a8a7409ebbb940e352722588a8e0bb106">TOffer::Operation::DESTROY</a>);</div>
-<div class="line"><a name="l01180"></a><span class="lineno"> 1180</span>  operation.mutable_destroy()->mutable_volumes()->CopyFrom(volumes);</div>
-<div class="line"><a name="l01181"></a><span class="lineno"> 1181</span>  <span class="keywordflow">return</span> operation;</div>
-<div class="line"><a name="l01182"></a><span class="lineno"> 1182</span> }</div>
-<div class="line"><a name="l01183"></a><span class="lineno"> 1183</span> </div>
-<div class="line"><a name="l01184"></a><span class="lineno"> 1184</span> </div>
-<div class="line"><a name="l01185"></a><span class="lineno"> 1185</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TOffer, <span class="keyword">typename</span> TTaskInfo></div>
-<div class="line"><a name="l01186"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a5e5ce150a3e1b42ffcc0fd9e5ed659ab"> 1186</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a5e5ce150a3e1b42ffcc0fd9e5ed659ab">LAUNCH</a>(<span class="keyword">const</span> std::vector<TTaskInfo>& tasks)</div>
-<div class="line"><a name="l01187"></a><span class="lineno"> 1187</span> {</div>
-<div class="line"><a name="l01188"></a><span class="lineno"> 1188</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
-<div class="line"><a name="l01189"></a><span class="lineno"> 1189</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a5e5ce150a3e1b42ffcc0fd9e5ed659ab">TOffer::Operation::LAUNCH</a>);</div>
+<div class="line"><a name="l01155"></a><span class="lineno"> 1155</span> <span class="comment">// Helper to create DomainInfo.</span></div>
+<div class="line"><a name="l01156"></a><span class="lineno"> 1156</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TDomainInfo></div>
+<div class="line"><a name="l01157"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a350e4f6f831f99d6a3b6f17cdc4f9765"> 1157</a></span> <span class="keyword">inline</span> TDomainInfo <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a350e4f6f831f99d6a3b6f17cdc4f9765">createDomainInfo</a>(</div>
+<div class="line"><a name="l01158"></a><span class="lineno"> 1158</span>  <span class="keyword">const</span> std::string& regionName,</div>
+<div class="line"><a name="l01159"></a><span class="lineno"> 1159</span>  <span class="keyword">const</span> std::string& zoneName)</div>
+<div class="line"><a name="l01160"></a><span class="lineno"> 1160</span> {</div>
+<div class="line"><a name="l01161"></a><span class="lineno"> 1161</span>  TDomainInfo domain;</div>
+<div class="line"><a name="l01162"></a><span class="lineno"> 1162</span> </div>
+<div class="line"><a name="l01163"></a><span class="lineno"> 1163</span>  domain.mutable_fault_domain()->mutable_region()->set_name(regionName);</div>
+<div class="line"><a name="l01164"></a><span class="lineno"> 1164</span>  domain.mutable_fault_domain()->mutable_zone()->set_name(zoneName);</div>
+<div class="line"><a name="l01165"></a><span class="lineno"> 1165</span> </div>
+<div class="line"><a name="l01166"></a><span class="lineno"> 1166</span>  <span class="keywordflow">return</span> domain;</div>
+<div class="line"><a name="l01167"></a><span class="lineno"> 1167</span> }</div>
+<div class="line"><a name="l01168"></a><span class="lineno"> 1168</span> </div>
+<div class="line"><a name="l01169"></a><span class="lineno"> 1169</span> </div>
+<div class="line"><a name="l01170"></a><span class="lineno"> 1170</span> <span class="comment">// Helpers for creating offer operations.</span></div>
+<div class="line"><a name="l01171"></a><span class="lineno"> 1171</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TOffer></div>
+<div class="line"><a name="l01172"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a07ba9c332393ad463065495f37c5bced"> 1172</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a07ba9c332393ad463065495f37c5bced">RESERVE</a>(<span class="keyword">const</span> TResources& resources)</div>
+<div class="line"><a name="l01173"></a><span class="lineno"> 1173</span> {</div>
+<div class="line"><a name="l01174"></a><span class="lineno"> 1174</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
+<div class="line"><a name="l01175"></a><span class="lineno"> 1175</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a07ba9c332393ad463065495f37c5bced">TOffer::Operation::RESERVE</a>);</div>
+<div class="line"><a name="l01176"></a><span class="lineno"> 1176</span>  operation.mutable_reserve()->mutable_resources()->CopyFrom(resources);</div>
+<div class="line"><a name="l01177"></a><span class="lineno"> 1177</span>  <span class="keywordflow">return</span> operation;</div>
+<div class="line"><a name="l01178"></a><span class="lineno"> 1178</span> }</div>
+<div class="line"><a name="l01179"></a><span class="lineno"> 1179</span> </div>
+<div class="line"><a name="l01180"></a><span class="lineno"> 1180</span> </div>
+<div class="line"><a name="l01181"></a><span class="lineno"> 1181</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TOffer></div>
+<div class="line"><a name="l01182"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a7502aad15971920c0d5907ca2f010859"> 1182</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a7502aad15971920c0d5907ca2f010859">UNRESERVE</a>(<span class="keyword">const</span> TResources& resources)</div>
+<div class="line"><a name="l01183"></a><span class="lineno"> 1183</span> {</div>
+<div class="line"><a name="l01184"></a><span class="lineno"> 1184</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
+<div class="line"><a name="l01185"></a><span class="lineno"> 1185</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a7502aad15971920c0d5907ca2f010859">TOffer::Operation::UNRESERVE</a>);</div>
+<div class="line"><a name="l01186"></a><span class="lineno"> 1186</span>  operation.mutable_unreserve()->mutable_resources()->CopyFrom(resources);</div>
+<div class="line"><a name="l01187"></a><span class="lineno"> 1187</span>  <span class="keywordflow">return</span> operation;</div>
+<div class="line"><a name="l01188"></a><span class="lineno"> 1188</span> }</div>
+<div class="line"><a name="l01189"></a><span class="lineno"> 1189</span> </div>
<div class="line"><a name="l01190"></a><span class="lineno"> 1190</span> </div>
-<div class="line"><a name="l01191"></a><span class="lineno"> 1191</span>  <span class="keywordflow">foreach</span> (<span class="keyword">const</span> TTaskInfo& task, tasks) {</div>
-<div class="line"><a name="l01192"></a><span class="lineno"> 1192</span>  operation.mutable_launch()->add_task_infos()->CopyFrom(task);</div>
-<div class="line"><a name="l01193"></a><span class="lineno"> 1193</span>  }</div>
-<div class="line"><a name="l01194"></a><span class="lineno"> 1194</span> </div>
-<div class="line"><a name="l01195"></a><span class="lineno"> 1195</span>  <span class="keywordflow">return</span> operation;</div>
-<div class="line"><a name="l01196"></a><span class="lineno"> 1196</span> }</div>
-<div class="line"><a name="l01197"></a><span class="lineno"> 1197</span> </div>
-<div class="line"><a name="l01198"></a><span class="lineno"> 1198</span> </div>
-<div class="line"><a name="l01199"></a><span class="lineno"> 1199</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TExecutorInfo, <span class="keyword">typename</span> TTaskGroupInfo, <span class="keyword">typename</span> TOffer></div>
-<div class="line"><a name="l01200"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ac32a101c068371a2114b0f63a0c45db2"> 1200</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ac32a101c068371a2114b0f63a0c45db2">LAUNCH_GROUP</a>(</div>
-<div class="line"><a name="l01201"></a><span class="lineno"> 1201</span>  <span class="keyword">const</span> TExecutorInfo& executorInfo,</div>
-<div class="line"><a name="l01202"></a><span class="lineno"> 1202</span>  <span class="keyword">const</span> TTaskGroupInfo& taskGroup)</div>
+<div class="line"><a name="l01191"></a><span class="lineno"> 1191</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TOffer></div>
+<div class="line"><a name="l01192"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3fe53df8c99e8dce61568ce527030ce7"> 1192</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3fe53df8c99e8dce61568ce527030ce7">CREATE</a>(<span class="keyword">const</span> TResources& volumes)</div>
+<div class="line"><a name="l01193"></a><span class="lineno"> 1193</span> {</div>
+<div class="line"><a name="l01194"></a><span class="lineno"> 1194</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
+<div class="line"><a name="l01195"></a><span class="lineno"> 1195</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a3fe53df8c99e8dce61568ce527030ce7">TOffer::Operation::CREATE</a>);</div>
+<div class="line"><a name="l01196"></a><span class="lineno"> 1196</span>  operation.mutable_create()->mutable_volumes()->CopyFrom(volumes);</div>
+<div class="line"><a name="l01197"></a><span class="lineno"> 1197</span>  <span class="keywordflow">return</span> operation;</div>
+<div class="line"><a name="l01198"></a><span class="lineno"> 1198</span> }</div>
+<div class="line"><a name="l01199"></a><span class="lineno"> 1199</span> </div>
+<div class="line"><a name="l01200"></a><span class="lineno"> 1200</span> </div>
+<div class="line"><a name="l01201"></a><span class="lineno"> 1201</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TResources, <span class="keyword">typename</span> TOffer></div>
+<div class="line"><a name="l01202"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a8a7409ebbb940e352722588a8e0bb106"> 1202</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a8a7409ebbb940e352722588a8e0bb106">DESTROY</a>(<span class="keyword">const</span> TResources& volumes)</div>
<div class="line"><a name="l01203"></a><span class="lineno"> 1203</span> {</div>
<div class="line"><a name="l01204"></a><span class="lineno"> 1204</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
-<div class="line"><a name="l01205"></a><span class="lineno"> 1205</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#ac32a101c068371a2114b0f63a0c45db2">TOffer::Operation::LAUNCH_GROUP</a>);</div>
-<div class="line"><a name="l01206"></a><span class="lineno"> 1206</span>  operation.mutable_launch_group()->mutable_executor()->CopyFrom(executorInfo);</div>
-<div class="line"><a name="l01207"></a><span class="lineno"> 1207</span>  operation.mutable_launch_group()->mutable_task_group()->CopyFrom(taskGroup);</div>
-<div class="line"><a name="l01208"></a><span class="lineno"> 1208</span>  <span class="keywordflow">return</span> operation;</div>
-<div class="line"><a name="l01209"></a><span class="lineno"> 1209</span> }</div>
+<div class="line"><a name="l01205"></a><span class="lineno"> 1205</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a8a7409ebbb940e352722588a8e0bb106">TOffer::Operation::DESTROY</a>);</div>
+<div class="line"><a name="l01206"></a><span class="lineno"> 1206</span>  operation.mutable_destroy()->mutable_volumes()->CopyFrom(volumes);</div>
+<div class="line"><a name="l01207"></a><span class="lineno"> 1207</span>  <span class="keywordflow">return</span> operation;</div>
+<div class="line"><a name="l01208"></a><span class="lineno"> 1208</span> }</div>
+<div class="line"><a name="l01209"></a><span class="lineno"> 1209</span> </div>
<div class="line"><a name="l01210"></a><span class="lineno"> 1210</span> </div>
-<div class="line"><a name="l01211"></a><span class="lineno"> 1211</span> </div>
-<div class="line"><a name="l01212"></a><span class="lineno"> 1212</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TParameters, <span class="keyword">typename</span> TParameter></div>
-<div class="line"><a name="l01213"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#acfb7d6b4d5a646c620b8aba7f2f2c4fa"> 1213</a></span> <span class="keyword">inline</span> TParameters <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#acfb7d6b4d5a646c620b8aba7f2f2c4fa">parameterize</a>(<span class="keyword">const</span> ACLs& acls)</div>
-<div class="line"><a name="l01214"></a><span class="lineno"> 1214</span> {</div>
-<div class="line"><a name="l01215"></a><span class="lineno"> 1215</span>  TParameters parameters;</div>
-<div class="line"><a name="l01216"></a><span class="lineno"> 1216</span>  TParameter* parameter = parameters.add_parameter();</div>
-<div class="line"><a name="l01217"></a><span class="lineno"> 1217</span>  parameter->set_key(<span class="stringliteral">"acls"</span>);</div>
-<div class="line"><a name="l01218"></a><span class="lineno"> 1218</span>  parameter->set_value(std::string(<a class="code" href="jsonify_8hpp.html#ab2d3ecf67ed06919e96e5e97b2effdc3">jsonify</a>(<a class="code" href="structJSON_1_1Protobuf.html">JSON::Protobuf</a>(acls))));</div>
-<div class="line"><a name="l01219"></a><span class="lineno"> 1219</span> </div>
-<div class="line"><a name="l01220"></a><span class="lineno"> 1220</span>  <span class="keywordflow">return</span> parameters;</div>
-<div class="line"><a name="l01221"></a><span class="lineno"> 1221</span> }</div>
-<div class="line"><a name="l01222"></a><span class="lineno"> 1222</span> } <span class="comment">// namespace common {</span></div>
+<div class="line"><a name="l01211"></a><span class="lineno"> 1211</span> <span class="keyword">template</span> <<span class="keyword">typename</span> TOffer, <span class="keyword">typename</span> TTaskInfo></div>
+<div class="line"><a name="l01212"></a><span class="lineno"><a class="line" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a5e5ce150a3e1b42ffcc0fd9e5ed659ab"> 1212</a></span> <span class="keyword">inline</span> <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> <a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a5e5ce150a3e1b42ffcc0fd9e5ed659ab">LAUNCH</a>(<span class="keyword">const</span> std::vector<TTaskInfo>& tasks)</div>
+<div class="line"><a name="l01213"></a><span class="lineno"> 1213</span> {</div>
+<div class="line"><a name="l01214"></a><span class="lineno"> 1214</span>  <span class="keyword">typename</span> <a class="code" href="namespacecgroups_1_1blkio.html#a350b1eb57318afaea7700ab7786b55ef">TOffer::Operation</a> operation;</div>
+<div class="line"><a name="l01215"></a><span class="lineno"> 1215</span>  operation.set_type(<a class="code" href="namespacemesos_1_1internal_1_1tests_1_1common.html#a5e5ce150a3e1b42ffcc0fd9e5ed659ab">TOffer::Operation::LAUNCH</a>);</div>
+<div class="line"><a name="l01216"></a><span class="lineno"> 1216</span> </div>
+<div class="line"><a name="l01217"></a><span class="lineno"> 1217</span>  <span class="keywordflow">foreach</span> (<span class="keyword">const</span> TTaskInfo& task, tasks) {</div>
+<div class="line"><a name="l01218"></a><span class="lineno"> 1218</span>  operation.mutable_launch()->add_task_infos()->CopyFrom(task);</div>
+<div class="line"><a name="l01219"></a><span class="lineno"> 1219</span>  }</div>
+<div class="line"><a name="l01220"></a><span class="lineno"> 1220</span> </div>
+<div class="line"><a name="l01221"></a><span class="lineno"> 1221</span>  <span class="keywordflow">return</span> operation;</div>
+<div class="line"><a name="l01222"></a><span class="lineno"> 1222</span> }</div>
<div class="line"><a name="l01223"></a><span class="lineno"> 1223</span> </div>
<div class="line"><a name="l
<TRUNCATED>