-
Notifications
You must be signed in to change notification settings - Fork 5.4k
Add RunSample target to mono.proj #2393
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from all commits
a47178e
c76494f
c5121da
312f60b
562adf8
691fc3c
7e1d20d
758e482
9446e42
1f9188c
462dc21
76acb13
4b65117
5fb59f6
55fba2d
f746fa8
99f89cf
344b05e
695c25c
7ec8353
4ccea53
b9b4a64
27bf198
3df9964
0583a93
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change |
|---|---|---|
|
|
@@ -5,6 +5,17 @@ | |
| <PropertyGroup> | ||
| <MonoObjDir>$(ArtifactsObjDir)mono/$(PlatformConfigPathPart)/</MonoObjDir> | ||
| <MonoEnableLLVM Condition=" '$(MonoEnableLLVM)' == '' ">false</MonoEnableLLVM> | ||
| <DotNetExec Condition="'$(OS)' == 'Windows_NT'">dotnet.exe</DotNetExec> | ||
| <DotNetExec Condition="'$(DotNetExec)' == ''">dotnet</DotNetExec> | ||
| <LocalDotnetDir>..\..\.dotnet</LocalDotnetDir> | ||
| <LocalDotnet>$(LocalDotnetDir)\$(DotNetExec)</LocalDotnet> | ||
| <ScriptExt Condition="'$(OS)' == 'Windows_NT'">.cmd</ScriptExt> | ||
| <ScriptExt Condition="'$(OS)' != 'Windows_NT'">.sh</ScriptExt> | ||
| <_CoreClrFileName Condition="'$(TargetsWindows)' == 'true'">coreclr.dll</_CoreClrFileName> | ||
| <_CoreClrFileName Condition="'$(TargetsOSX)' == 'true'">libcoreclr.dylib</_CoreClrFileName> | ||
| <_CoreClrFileName Condition="'$(_CoreClrFileName)' == ''">libcoreclr.so</_CoreClrFileName> | ||
| <CoreClrTestConfig Condition="'$(CoreClrTestConfig)' == ''">$(Configuration)</CoreClrTestConfig> | ||
| <CoreClrTestCoreRoot>$(ArtifactsDir)tests\coreclr\$(OSGroup).$(Platform).$(CoreClrTestConfig)\Tests\Core_Root</CoreClrTestCoreRoot> | ||
| </PropertyGroup> | ||
|
|
||
| <!-- OSX/Linux Mono runtime build --> | ||
|
|
@@ -52,10 +63,6 @@ | |
| <_MonoRuntimeFilePath Condition="'$(TargetsWindows)' == 'true' and '$(Platform)' == 'x86'">$(MonoObjDir)Win32\Bin\$(Configuration)\mono-2.0-sgen.dll</_MonoRuntimeFilePath> | ||
| <_MonoRuntimeFilePath Condition="'$(TargetsOSX)' == 'true'">$(MonoObjDir)mono\mini\.libs\libmonosgen-2.0.dylib</_MonoRuntimeFilePath> | ||
| <_MonoRuntimeFilePath Condition="'$(_MonoRuntimeFilePath)' == ''">$(MonoObjDir)mono\mini\.libs\libmonosgen-2.0.so</_MonoRuntimeFilePath> | ||
|
|
||
| <_CoreClrFileName Condition="'$(TargetsWindows)' == 'true'">coreclr.dll</_CoreClrFileName> | ||
| <_CoreClrFileName Condition="'$(TargetsOSX)' == 'true'">libcoreclr.dylib</_CoreClrFileName> | ||
| <_CoreClrFileName Condition="'$(_CoreClrFileName)' == ''">libcoreclr.so</_CoreClrFileName> | ||
| </PropertyGroup> | ||
|
|
||
| <!-- Copy Mono runtime files to artifacts directory --> | ||
|
|
@@ -81,4 +88,80 @@ | |
|
|
||
| <Target Name="Test" /> | ||
|
|
||
| <!-- Copy Mono runtime bits to the local .dotnet dir for local experiments (temp solution) --> | ||
| <Target Name="PatchLocalDotnet" DependsOnTargets="ValidateLocalDotnet"> | ||
| <PropertyGroup> | ||
| <LocalDotnetRuntimeDir>$([System.IO.Directory]::GetDirectories("$(LocalDotnetDir)\shared\Microsoft.NETCore.App")[0])</LocalDotnetRuntimeDir> | ||
| </PropertyGroup> | ||
| <ItemGroup> | ||
| <_MonoRuntimeArtifacts Include="$(BinDir)\*.*" /> | ||
| </ItemGroup> | ||
| <Copy SourceFiles="$(_MonoRuntimeArtifacts)" | ||
| DestinationFolder="$(LocalDotnetRuntimeDir)" | ||
| SkipUnchangedFiles="true" /> | ||
| </Target> | ||
|
|
||
| <!-- Copy Coreclr runtime bits to the local .dotnet dir --> | ||
| <Target Name="RestoreLocalDotnet" DependsOnTargets="ValidateLocalDotnet"> | ||
| <Copy SourceFiles="$(CoreCLRArtifactsPath)\System.Private.CoreLib.dll" | ||
| DestinationFiles="$(LocalDotnetRuntimeDir)\System.Private.CoreLib.dll" /> | ||
| <Copy SourceFiles="$(CoreCLRArtifactsPath)\$(_CoreClrFileName)" | ||
| DestinationFiles="$(LocalDotnetRuntimeDir)\$(_CoreClrFileName)" /> | ||
| </Target> | ||
|
|
||
| <!-- Copy Mono runtime bits to the coreclr's Core_Root in order to run runtime tests --> | ||
| <Target Name="PatchCoreClrCoreRoot" DependsOnTargets="ValidateLocalDotnet"> | ||
| <Error Condition="!Exists('$(CoreClrTestCoreRoot)')" Text="Core_Root ($(CoreClrTestCoreRoot)) doesn't exist. Have you built coreclr tests in $(CoreClrTestConfig) configuration?" /> | ||
| <ItemGroup> | ||
| <_MonoRuntimeArtifacts Include="$(BinDir)\*.*" /> | ||
| </ItemGroup> | ||
| <Copy SourceFiles="@(_MonoRuntimeArtifacts)" | ||
| DestinationFolder="$(CoreClrTestCoreRoot)" | ||
| SkipUnchangedFiles="true"/> | ||
| </Target> | ||
|
|
||
| <!-- Copy Coreclr runtime bits back to Core_Root --> | ||
| <Target Name="RestoreCoreClrCoreRoot" DependsOnTargets="ValidateLocalDotnet"> | ||
| <Copy SourceFiles="$(CoreCLRArtifactsPath)\System.Private.CoreLib.dll" | ||
| DestinationFiles="$(CoreClrTestCoreRoot)\System.Private.CoreLib.dll" /> | ||
| <Copy SourceFiles="$(CoreCLRArtifactsPath)\$(_CoreClrFileName)" | ||
| DestinationFiles="$(CoreClrTestCoreRoot)\$(_CoreClrFileName)" /> | ||
| </Target> | ||
|
|
||
| <!-- Run netcore\sample\HelloWorld sample using Mono Runtime --> | ||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I am not sure it's worth it. I'd prefer to have better documentation for this instead
Member
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @marek-safar um.. what exactly is not worth it? -- having the RunSample target?
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. yeah, I'd much rather see documentation with working steps for
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Wouldn't this have temporary value until we figure that part out? I know some people like to use RunSample as an easy way to test their stuff.
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I guess we figure it out already if we can run the sample which is form of
Member
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I see what you mean. Yeah, I agree.
Member
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. it seems most of us use HelloWorld for experiments/fixes/improvements. Do you suggest to remove it and let everybody do: instead of Currently
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. yep, I think having this document something is more valuable than having it in Makefile (although you can keep sample of this example if you think it's valuable)
Member
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I've simplified all the things so now runsample uses local dotnet. But I personally would prefer to keep it at least for a while. |
||
| <Target Name="RunSample" DependsOnTargets="PatchLocalDotnet"> | ||
| <Exec Command="$(LocalDotnet) run -c Release -f $(NetCoreAppCurrent) -p $(MonoProjectRoot)netcore\sample\HelloWorld" /> | ||
| </Target> | ||
|
|
||
| <!-- Run CoreCLR runtime test using testhost --> | ||
| <Target Name="RunCoreClrTest" DependsOnTargets="ValidateLocalDotnet;PatchCoreClrCoreRoot"> | ||
| <Error Condition="$(CoreClrTest) == ''" Text="'CoreClrTest' is not set. E.g. set it to `$(ArtifactsDir)tests/coreclr/$(OSGroup).$(Platform).$(CoreClrTestConfig)/JIT/opt/InstructionCombining/DivToMul/DivToMul$(ScriptExt)` in order to run DivToMul test." /> | ||
| <Exec Command="$(CoreClrTest) -coreroot="$(CoreClrTestCoreRoot)""/> | ||
| </Target> | ||
|
|
||
| <!-- Make sure coreclr tests are built (in $(CoreClrTestConfig) configuration), e.g. | ||
| *nix: `cd ../coreclr && ./build.sh -release && ./build-testh.sh -release` | ||
| Windows: `cd ../coreclr && build.cmd -release` --> | ||
| <Target Name="RunCoreClrTests" DependsOnTargets="ValidateLocalDotnet;PatchCoreClrCoreRoot"> | ||
| <ItemGroup> | ||
| <CoreClrTests Include="$(ArtifactsDir)tests\coreclr\$(OSGroup).$(Platform).$(CoreClrTestConfig)\**\*$(ScriptExt)" /> | ||
| </ItemGroup> | ||
| <Exec Condition="'$(OS)' == 'Windows_NT'" Command=""%(CoreClrTests.Identity)" -coreroot "$(CoreClrTestCoreRoot)"" ContinueOnError="WarnAndContinue" /> | ||
| <Exec Condition="'$(OS)' != 'Windows_NT'" Command="bash "%(CoreClrTests.Identity)" -coreroot="$(CoreClrTestCoreRoot)"" ContinueOnError="WarnAndContinue" /> | ||
| </Target> | ||
|
|
||
| <!-- Show summary for coreclr tests --> | ||
| <Target Name="CoreClrTestsSummary"> | ||
| <Exec Command="python $(MonoProjectRoot)..\coreclr\tests\runtest.py --analyze_results_only -test_location $(ArtifactsDir)tests\coreclr\$(OSGroup).$(Platform).$(CoreClrTestConfig) -build_type $(CoreClrTestConfig)" /> | ||
| </Target> | ||
|
|
||
| <Target Name="RunBenchmarks"> | ||
| <Error Condition="$(BenchmarksRepo) == ''" Text="BenchmarksRepo variable is not set" /> | ||
EgorBo marked this conversation as resolved.
Show resolved
Hide resolved
|
||
| <Exec WorkingDirectory="$(BenchmarksRepo)\src\benchmarks\micro" Command="$(LocalDotnet) run -c Release -f $(NetCoreAppCurrent) --cli $(LocalDotnet)" /> | ||
| </Target> | ||
|
|
||
| <Target Name="ValidateLocalDotnet"> | ||
| <Error Condition="!Exists('$(LocalDotnet)')" Text="'$(LocalDotnet)' doesn't exist." /> | ||
| </Target> | ||
|
|
||
| </Project> | ||
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,38 @@ | ||
| DOTNET=../../../.dotnet/dotnet | ||
|
|
||
| # run sample using local .dotnet (will be patched with Mono Runtime) | ||
| run-sample: | ||
| $(DOTNET) msbuild /t:RunSample ../mono.proj | ||
|
|
||
| # run sample using dotnet from PATH | ||
| run-sample-coreclr: | ||
| dotnet run -c Release -p sample/HelloWorld -f netcoreapp3.1 | ||
|
|
||
| runtime: | ||
| $(DOTNET) msbuild /t:Build ../mono.proj | ||
|
|
||
| # temp: makes $(DOTNET) to use mono runtime (to run real-world apps using '$(DOTNET) run') | ||
| patch-local-dotnet: | ||
| $(DOTNET) msbuild /t:PatchLocalDotnet ../mono.proj | ||
|
|
||
| restore-local-dotnet: | ||
| $(DOTNET) msbuild /t:RestoreLocalDotnet ../mono.proj | ||
|
|
||
| # run specific coreclr test, e.g.: | ||
| # make run-tests-coreclr CoreClrTest="bash ../../artifacts/tests/coreclr/OSX.x64.Checked/JIT/opt/InstructionCombining/DivToMul/DivToMul.sh" | ||
| run-tests-coreclr: | ||
| $(DOTNET) msbuild /t:RunCoreClrTest /p:CoreClrTest="$(CoreClrTest)" ../mono.proj | ||
|
|
||
| # run all coreclr tests | ||
| run-tests-coreclr-all: | ||
| $(DOTNET) msbuild /t:RunCoreClrTests ../mono.proj | ||
|
|
||
| # show summary for coreclr tests | ||
| tests-coreclr-summary: | ||
| $(DOTNET) msbuild /t:CoreClrTestsSummary ../mono.proj | ||
|
|
||
| # run 'dotnet/performance' benchmarks | ||
| # e.g. 'make run-benchmarks BenchmarksRepo=/prj/performance' | ||
| # you can append BDN parameters at the end, e.g. ` -- --filter Burgers --keepFiles` | ||
| run-benchmarks: patch-local-dotnet | ||
| $(DOTNET) msbuild /t:RunBenchmarks /p:BenchmarksRepo=$(BenchmarksRepo) |
This file was deleted.
This file was deleted.
This file was deleted.
Uh oh!
There was an error while loading. Please reload this page.