<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Word 15 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
{font-family:"Cambria Math";
panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
{font-family:Calibri;
panose-1:2 15 5 2 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
{margin:0in;
margin-bottom:.0001pt;
font-size:11.0pt;
font-family:"Calibri",sans-serif;}
a:link, span.MsoHyperlink
{mso-style-priority:99;
color:#0563C1;
text-decoration:underline;}
span.EmailStyle21
{mso-style-type:personal-reply;
font-family:"Calibri",sans-serif;
color:windowtext;}
.MsoChpDefault
{mso-style-type:export-only;
font-size:10.0pt;}
@page WordSection1
{size:8.5in 11.0in;
margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
{page:WordSection1;}
--></style>
</head>
<body lang="EN-US" link="#0563C1" vlink="#954F72">
<div class="WordSection1">
<p class="MsoNormal">Beyond compiler support of C++17 features, f18 requires library support too, for, for example, std::variant, which became available in GCC 7.1.<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><a href="https://gcc.gnu.org/onlinedocs/libstdc++/manual/status.html#status.iso.2017">https://gcc.gnu.org/onlinedocs/libstdc++/manual/status.html#status.iso.2017</a><o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><a href="https://libcxx.llvm.org/cxx1z_status.html">https://libcxx.llvm.org/cxx1z_status.html</a><o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal">- Steve<o:p></o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<p class="MsoNormal"><o:p> </o:p></p>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b><span style="font-size:12.0pt;color:black">From: </span></b><span style="font-size:12.0pt;color:black">flang-dev <flang-dev-bounces@lists.llvm.org> on behalf of Richard Barton via flang-dev <flang-dev@lists.llvm.org><br>
<b>Reply-To: </b>Richard Barton <Richard.Barton@arm.com><br>
<b>Date: </b>Friday, November 15, 2019 at 12:35 AM<br>
<b>To: </b>David Truby <David.Truby@arm.com>, "flang-dev@lists.llvm.org" <flang-dev@lists.llvm.org><br>
<b>Subject: </b>Re: [flang-dev] Testing infrastructure for F18<o:p></o:p></span></p>
</div>
<div>
<p class="MsoNormal"><o:p> </o:p></p>
</div>
<p class="MsoNormal">Hi David<o:p></o:p></p>
<p class="MsoNormal"> <o:p></o:p></p>
<p class="MsoNormal">Thanks for all your work investigating and implementing this CI. I think this will be a great help to F18 stability and build its credibility as a project.<o:p></o:p></p>
<p class="MsoNormal"> <o:p></o:p></p>
<p class="MsoNormal">Your prototype adds CI jobs for AArch64 and x86_64 for clang-9 and GCC-9. The F18 Readme claims support for these build compilers:<o:p></o:p></p>
<p style="margin:0in;margin-bottom:.0001pt">“””<o:p></o:p></p>
<p style="margin:0in;margin-bottom:.0001pt">The code has been compiled and tested with GCC versions 7.2.0, 7.3.0, 8.1.0, and 8.2.0.<o:p></o:p></p>
<p style="margin:0in;margin-bottom:.0001pt">The code has been compiled and tested with clang version 7.0 and 8.0 using either GNU's libstdc++ or LLVM's libc++.<o:p></o:p></p>
<p class="MsoNormal">“””<o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959">From
<a href="https://github.com/flang-compiler/f18/blob/master/README.md">https://github.com/flang-compiler/f18/blob/master/README.md</a></span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959"> </span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal">How easy would it be to expand the CI to cover all of these compilers as well as the more modern ones you have tested with on both AArch64 and X86_64 so
as to test what we claim to support?</span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal"> </span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal">Once we have the CI stable, we should also update that readme to:</span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal">* add the newer versions of GCC and clang that we support in the CI</span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal">* add a statement of tested hardware platforms with x86 Linux and AArch64 Linux being the first two.</span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal">* Perhaps a statement of what has not been tested yet – Windows, Mac, x-compilation, etc.</span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal"> </span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal">I recall a conversation we had in the office where you told me some combination of build compiler and C++ runtime would not work to build F18 and that
the only fix was to change the version of one of these two components. I think we should also put a note in the readme explaining that restriction and suggesting a workaround. LLVM has a few of these - https://llvm.org/docs/GettingStarted.html#host-c-toolchain-both-compiler-and-standard-library.</span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal"> </span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal">Final thought: the LLVM project supports build compilers back to
</span></cite>GCC 5.1.0 and clang 3.9. Both of these claim near full C++17 support so might on paper be suitable for building F18. Has anyone tried these vintage compilers for F18?<o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal"> </span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal">Ta</span></cite><o:p></o:p></p>
<p class="MsoNormal"><cite><span style="font-family:"Calibri",sans-serif;color:#595959;font-style:normal">Rich</span></cite><o:p></o:p></p>
<p class="MsoNormal"> <o:p></o:p></p>
<div style="border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt">
<div>
<div style="border:none;border-top:solid #E1E1E1 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal"><b>From:</b> flang-dev <flang-dev-bounces@lists.llvm.org> <b>
On Behalf Of </b>David Truby via flang-dev<br>
<b>Sent:</b> 11 November, 2019 11:23<br>
<b>To:</b> flang-dev@lists.llvm.org<br>
<b>Cc:</b> nd <nd@arm.com><br>
<b>Subject:</b> [flang-dev] Testing infrastructure for F18<o:p></o:p></p>
</div>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">Hi all, <o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">I have been investigating the possibility of adding testing infrastructure to F18 on github, I have covered here the rationale and results of my investigation, and would appreciate some thoughts/feedback on whether this is something we
want to move forward with. <o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal"># Rationale<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">F18 currently has no testing infrastructure upstream. This has led to a few issues with certain additions breaking builds on certain compilers. Since it is unrealistic to expect developers to test with every compiler we claim to support,
some testing infrastructure should be in place to catch these issues. Such a measure would be a stop-gap until F18 is fully integrated into the upstream LLVM infrastructure, which has its own testing.<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal"># Investigated Services<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">A number of possible options were investigated for use as a CI service<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">for F18, but investigation focused on the following services:<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">* Travis CI<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">* Shippable<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">* Jenkins<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">* Drone CI<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">Since F18 is an upstream open source project, the preference was to attempt to use an externally accessible CI service rather than running a service internally on Arm servers; this discounted Jenkins as it requires self-hosting. Initially
Travis seemed promising as it is a commonly used service that is free for open source projects. However, Travis only gives access to test nodes with 2 CPU cores, 8GB of RAM and a 30 minute time limit: this is not sufficient for building F18.
<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">Shippable had similar issues due to having the same constraints on resources, however Shippable does allow a "bring your own node" mode where custom machines can be added to the CI for testing, similar to LLVM’s buildbot. This would require
provisioning nodes for CI though, and since this is a temporary measure it would be best to avoid that if possible.
<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">Drone CI is a newer service, and is less widely used and therefore less well documented than the other services investigated. However, the Drone cloud service is free for open source software and gives access to entire bare metal AMD and
Arm nodes provided by packet.com. This allows F18 to be built in a more reasonable time, making it feasible to use this for F18’s CI.<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal"># Drone CI<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">For the reasons listed above, Drone CI was selected for further investigation. It turned out to be fairly easy to add multiple build configurations to the drone .star file, and get pre-commit working with run times of around 10 minutes.
Currently this has been tested with clang-9/libc++ and gcc-9 on both amd64 and arm64. Other compilers and configurations can be added easily, so a discussion should be had as to what we want to actually test for.<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal"># User-facing consequences<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">I have implemented support for this CI on my own branch of f18 to check what the user-facing consequences of this look like. CI results are reported through the github UI, in two separate places: firstly, when a PR is submitted, on the
PR review page a notification will appear that CI is running, and will be updated to state whether the tests passed or failed. A link is given to the run on cloud.drone.io so that you can see which platform/compiler failed, and what the failure output was.
Additionally, after merging a PR, CI will run on the merged commit, and give a notification if it fails.
<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">Currently these pre- and post-commit runs run the same number of tests, as none of the f18 tests take very long to run. In future it would be possible to separate the tests into short and long tests, as LLVM does, and run the long tests
only after merging. However since this is a stop-gap measure until we move to LLVM’s testing infrastructure this might never be necessary.<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">It is possible to also set up emails to this mailing list (or a separate mailing list) with post-commit test failures if this is something that people would find useful.<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal"># Next steps<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">If this is something we want to go ahead with, the next step is for me to submit a PR with the required CI configuration file. Once this is merged, someone with commit access will need to log in with their github account to cloud.drone.io
and activate CI for F18; this should be as simple as pressing a single activate button next to the repository name, however it may be necessary to change a couple of settings as well. After the CI has been activated on drone, the results should appear automatically
in the github UI as mentioned above.<o:p></o:p></p>
</div>
<p class="MsoNormal"> <o:p></o:p></p>
<div>
<p class="MsoNormal">Please let me know what you think.<o:p></o:p></p>
</div>
<div>
<p class="MsoNormal">David Truby<o:p></o:p></p>
</div>
</div>
</div>
<DIV>
<HR>
</DIV>
<DIV>This email message is for the sole use of the intended recipient(s) and may
contain confidential information. Any unauthorized review, use, disclosure
or distribution is prohibited. If you are not the intended recipient,
please contact the sender by reply email and destroy all copies of the original
message. </DIV>
<DIV>
<HR>
</DIV>
</body>
</html>