An incredibly simple and fast way to automate building and deployment Visual C++, .NET and UWP apps
Sapfire is a fastlane plugin that provides a bunch of actions to work with MSBuild, NuGet and Microsoft Store app submission.
MSBuild is a set of open-source build tools created by Microsoft. It is included with Visual Studio, but also can be used independently via command-line interface.
NuGet is a package manager, primarily used for packaging and distributing software written using the .NET.
Microsoft Store is a digital distribution platform for Windows.
To get started working with plugin, add it to your project by running:
fastlane add_plugin sapfire
Or, if you want to pick the latest commit from the repository, add this to fastlane/Pluginfile
:
gem "fastlane-plugin-sapfire", git: "https://github.com/fastlane/fastlane-plugin-sapfire.git"
First of all it's important to denote that some of actions or their parameters (such as msbuild
for UWP) are working
on Windows only. Currently fastlane is not officially supported on this platform. Despite this fact it's still possible to run it.
Actions or parameters with such restriction contain the corresponding mark in documentation.
If you want to use them, be sure that the platform name of the build lanes is windows:
platform :windows do
# your lanes
end
Once installed, the information for an action can be printed out with this command:
fastlane action msbuild # or any action included with this plugin
Here is the list of all available actions. Read the documentation on each one by clicking on the action name.
Argument | Description | Supported platforms |
---|---|---|
msbuild_select | Changes the MSBuild executable to use | all |
msbuild | Wraps all parameters and executes MSBuild | all |
build_uwp_app | Alias for the msbuild action with additional parameters for UWP |
windows |
dotnet_select | Changes the dotnet executable to use | all |
ensure_dotnet_version | Ensures the right version of .NET is installed and can be used | all |
associate_ms_store | Makes a local app manifest needed for Microsoft Store association | windows |
nuget_pack | Executes MSBuild to create a NuGet package | all |
Argument | Description | Supported platforms |
---|---|---|
update_uwp_signing_settings | Configures UWP package signing settings | windows |
Argument | Description | Supported platforms |
---|---|---|
app_certification | Runs Windows App Certification Kit to ensure your app is safe and efficient | windows |
Argument | Description | Supported platforms |
---|---|---|
upload_ms_store | Uploads new binary to Microsoft Partner Center | windows |
upload_nuget | Pushes a package to the server and publishes it | all |
Argument | Description | Supported platforms |
---|---|---|
ms_credentials | Sets Azure AD credentials for further actions | windows |
In addition this plugin provides a parser module for Microsoft SLN file format.
To open a solution, run this:
require "fastlane/plugin/sapfire/sln_project/sln_project"
root_block = Module.open("/cygdrive/c/Projects/My_Project.sln")
puts root_block.projects[0] # print name of the first subproject in solution
To run both the tests, and code style validation, run
rake
To automatically fix many of the styling issues, use
rubocop -a
For any other issues and feedback about this plugin, please open a GitHub issue.
If you have trouble using plugins, check out the Plugins Troubleshooting guide.
For more information about how the fastlane
plugin system works, check out the Plugins documentation.
fastlane is the easiest way to automate beta deployments and releases for your iOS and Android apps. To learn more, check out fastlane.tools.
This project is licensed under the MIT license.