Skip to content

Commit

Permalink
doc: update README
Browse files Browse the repository at this point in the history
  • Loading branch information
Guven Karanfil committed Jun 11, 2024
1 parent 198adcb commit 5e53885
Show file tree
Hide file tree
Showing 5 changed files with 72 additions and 25 deletions.
90 changes: 66 additions & 24 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,40 +1,84 @@
# appcircle_testing_distribution plugin
## Appcircle Testing Distribution

[![fastlane Plugin Badge](https://rawcdn.githack.com/fastlane/fastlane/master/fastlane/assets/plugin-badge.svg)](https://rubygems.org/gems/fastlane-plugin-appcircle_testing_distribution)

## Getting Started
Appcircle simplifies the distribution of builds to test teams with an extensive platform for managing and tracking applications, versions, testers, and teams. Appcircle integrates with enterprise authentication mechanisms such as LDAP and SSO, ensuring secure distribution of testing packages. Learn more about Appcircle testing distribution. Learn more about [Appcircle testing distribution](https://appcircle.io/testing-distribution)

This project is a [_fastlane_](https://github.com/fastlane/fastlane) plugin. To get started with `fastlane-plugin-appcircle_testing_distribution`, add it to your project by running:
Appcircle's test distribution extension enables developers to create test groups and share builds with them, utilizing enterprise-grade authentication methods. With the Fastlane plugin, this module will be accessible directly fastlane actions.

```bash
fastlane add_plugin appcircle_testing_distribution
```
## Exploring Testing Distribution

## About appcircle_testing_distribution
Testing distribution is the process of distributing test builds to designated test groups or individuals. This process allows developers to gather quick feedback, identify bugs, and ensure the quality of software applications before releasing them to customers. Appcircle's test distribution module enables developers to create test groups and share builds with them, utilizing enterprise-grade authentication methods.

Efficiently distribute application builds to users or testing groups using Appcircle's robust platform.
## Benefits of Using Testing Distribution

**Note to author:** Add a more detailed description about this plugin here. If your plugin contains multiple actions, make sure to mention them here.
1. **Simplified Binary Distribution**.
- **Skip Traditional Stores:** Share .xcarchive .IPA, APK, AAB, Zip, files directly, avoiding the need to use App Store TestFlight or Google Play Internal Testing.
2. **Streamlined Workflow:**
- **Automated Processes:** Platforms like Appcircle automate the distribution process, saving time and reducing manual effort.
- **Seamless Integration:** Integrates smoothly with existing DevOps pipelines, enabling efficient build and distribution workflows.
3. **Enhanced Security:**
- **Controlled Access:** Set specific permissions for who can access the test builds using enterprise authentication methods such as LDAP & SSO.
- **Confidentiality:** Ensures that only authorized testers have access to the builds, protecting sensitive information.
4. **Efficient Resource Management:**
- **Targeted Testing:** Allows the creation of specific test groups, ensuring that the right people are testing the right features.
- **Optimized Testing:** Helps in allocating resources effectively, leading to better utilization of testing resources.
5. **Reduced Time to Market:**
- **Eliminates Approval Delays:** By bypassing store approval processes, developers can distribute builds directly to testers, speeding up the testing cycle.
- **Continuous Delivery:** Supports continuous delivery practices, enabling faster iterations and quicker releases.
6. **Faster Feedback Loop:**
- **Quick Issue Identification:** Distributing test builds quickly allows developers to gather immediate feedback, identify bugs, and address issues early in the development cycle.
- **Improved Quality:** Continuous testing helps ensure the software meets quality standards before release, reducing the likelihood of post-release issues.
7. **Cost-Effective:**
- **Reduced Overheads:** Automating the distribution reduces the need for manual intervention, cutting down operational costs.
- **Efficient Bug Fixes:** Early detection and fixing of bugs prevent costly fixes later in the development process.
8. **Enhanced User Experience:**
- **Better Quality Control:** Ensures that end users receive a more stable and polished product.
- **Customer Satisfaction:** By delivering higher quality software, customer satisfaction and trust in the product increase.

## Example
Overall, using testing distribution in mobile DevOps significantly enhances the efficiency, security, and effectiveness of the software development process, leading to better products and faster delivery times.

Check out the [example `Fastfile`](fastlane/Fastfile) to see how to use this plugin. Try it by cloning the repo, running `fastlane install_plugins` and `bundle exec fastlane test`.
### Testing Distribution

**Note to author:** Please set up a sample project to make it easy for users to explore what your plugin does. Provide everything that is necessary to try out the plugin in this project (including a sample Xcode/Android project if necessary)
In order to share your builds with testers, you can create distribution profiles and assign testing groups to the distribution profiles.

## Run tests for this plugin
![Distribution Profile](images/distribution-start.png)

To run both the tests, and code style validation, run
### Generating/Managing the Personal API Tokens

```
rake
```
To generate a Personal API Token, follow these steps:

1. Go to the My Organization screen (the second option at the bottom left).
2. You'll find the Personal API Token section in the top right corner.
3. Press the "Generate Token" button to generate your first token.

![Token Generation](images/PAT.png)

## Getting Started with the Extension: Usage Guide

To share your builds with testers, you can create distribution profiles and assign testing groups to these profiles.

To automatically fix many of the styling issues, use
This project is a [_fastlane_](https://github.com/fastlane/fastlane) plugin. To get started with `fastlane-plugin-appcircle_testing_distribution`, add it to your project by running:

```bash
fastlane add_plugin appcircle_testing_distribution
```
rubocop -a

```yml
appcircle_testing_distribution(
accessToken: "$(AC_ACCESS_TOKEN)",
profileID: "$(AC_PROFILE_ID)",
appPath: "$(AC_APP_PATH)",
message: "$(AC_MESSAGE)",
)
```

### Leveraging Environment Variables

Utilize environment variables seamlessly by substituting the parameters with `$(VARIABLE_NAME)` in your task inputs. The extension automatically retrieves values from the specified environment variables within your pipeline.

Efficiently distribute test binaries or beta versions using Appcircle, featuring seamless IPA and APK distribution capabilities. Streamline your testing process with our versatile tool designed to optimize your distribution workflow. If you need support or more information, please [contact us](https://appcircle.io/contact)

## Issues and Feedback

For any other issues and feedback about this plugin, please submit it to this repository.
Expand All @@ -43,10 +87,8 @@ For any other issues and feedback about this plugin, please submit it to this re

If you have trouble using plugins, check out the [Plugins Troubleshooting](https://docs.fastlane.tools/plugins/plugins-troubleshooting/) guide.

## Using _fastlane_ Plugins

For more information about how the `fastlane` plugin system works, check out the [Plugins documentation](https://docs.fastlane.tools/plugins/create-plugin/).
### Reference

## About _fastlane_
- For details on generating an Appcircle Personal Access Token, visit [Generating/Managing Personal API Tokens](https://docs.appcircle.io/appcircle-api/api-authentication#generatingmanaging-the-personal-api-tokens)

_fastlane_ is the easiest way to automate beta deployments and releases for your iOS and Android apps. To learn more, check out [fastlane.tools](https://fastlane.tools).
- To create or learn more about Appcircle testing and distribution profiles, please refer to [Creating or Selecting a Distribution Profile](https://docs.appcircle.io/distribute/create-or-select-a-distribution-profile)
7 changes: 6 additions & 1 deletion fastlane/Fastfile
Original file line number Diff line number Diff line change
@@ -1,3 +1,8 @@
lane :test do
appcircle_testing_distribution
appcircle_testing_distribution(
accessToken: "$(AC_ACCESS_TOKEN)",
profileID: "$(AC_PROFILE_ID)",
appPath: "$(AC_APP_PATH)",
message: "$(AC_MESSAGE)",
)
end
Binary file added images/PAT.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added images/distribution-start.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added images/extension-icon.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 5e53885

Please sign in to comment.