From 4c07b54aa2f2ade8d2f6608e9f0cbedfa878fc45 Mon Sep 17 00:00:00 2001 From: per1234 Date: Fri, 9 Sep 2022 20:54:57 -0700 Subject: [PATCH 1/6] Move development documentation to a more suitable location Previously, information about project development was stored in a file named BUILDING.md in the root of the repository. That content is hereby moved to the file docs/development.md. This will provide the following benefits: - Broaden the scope of the file to all information related to development rather than building only - Store all documentation content under a single folder instead of randomly putting some in the root and others under docs --- BUILDING.md | 121 +------------------------------------------ README.md | 2 +- docs/development.md | 120 ++++++++++++++++++++++++++++++++++++++++++ docs/internal/Arm.md | 2 +- 4 files changed, 124 insertions(+), 121 deletions(-) create mode 100644 docs/development.md diff --git a/BUILDING.md b/BUILDING.md index b70bd0540..95c05f8f6 100644 --- a/BUILDING.md +++ b/BUILDING.md @@ -1,120 +1,3 @@ -# Development - -This page includes technical documentation for developers who want to build the IDE locally and contribute to the project. - -## Architecture overview - -The IDE consists of three major parts: - - the _Electron main_ process, - - the _backend_, and - - the _frontend_. - -The _Electron main_ process is responsible for: - - creating the application, - - managing the application lifecycle via listeners, and - - creating and managing the web pages for the app. - -In Electron, the process that runs the main entry JavaScript file is called the main process. The _Electron main_ process can display a GUI by creating web pages. An Electron app always has exactly one main process. - -By default, whenever the _Electron main_ process creates a web page, it will instantiate a new `BrowserWindow` instance. Since Electron uses Chromium for displaying web pages, Chromium's multi-process architecture is also used. Each web page in Electron runs in its own process, which is called the renderer process. Each `BrowserWindow` instance runs the web page in its own renderer process. When a `BrowserWindow` instance is destroyed, the corresponding renderer process is also terminated. The main process manages all web pages and their corresponding renderer processes. Each renderer process is isolated and only cares about the web page running in it.[[1]] - -In normal browsers, web pages usually run in a sandboxed environment, and accessing native resources are disallowed. However, Electron has the power to use Node.js APIs in the web pages allowing lower-level OS interactions. Due to security reasons, accessing native resources is an undesired behavior in the IDE. So by convention, we do not use Node.js APIs. (Note: the Node.js integration is [not yet disabled](https://github.com/eclipse-theia/theia/issues/2018) although it is not used). In the IDE, only the _backend_ allows OS interaction. - -The _backend_ process is responsible for: - - providing access to the filesystem, - - communicating with the [Arduino CLI](https://github.com/arduino/arduino-cli) via gRPC, - - running your terminal, - - exposing additional RESTful APIs, - - performing the Git commands in the local repositories, - - hosting and running any VS Code extensions, or - - executing VS Code tasks[[2]]. - -The _Electron main_ process spawns the _backend_ process. There is always exactly one _backend_ process. However, due to performance considerations, the _backend_ spawns several sub-processes for the filesystem watching, Git repository discovery, etc. The communication between the _backend_ process and its sub-processes is established via IPC. Besides spawning sub-processes, the _backend_ will start an HTTP server on a random available port, and serves the web application as static content. When the sub-processes are up and running, and the HTTP server is also listening, the _backend_ process sends the HTTP server port to the _Electron main_ process via IPC. The _Electron main_ process will load the _backend_'s endpoint in the `BrowserWindow`. - -The _frontend_ is running as an Electron renderer process and can invoke services implemented on the _backend_. The communication between the _backend_ and the _frontend_ is done via JSON-RPC over a websocket connection. This means, the services running in the _frontend_ are all proxies, and will ask the corresponding service implementation on the _backend_. - -[1]: https://www.electronjs.org/docs/tutorial/application-architecture#differences-between-main-process-and-renderer-process -[2]: https://code.visualstudio.com/Docs/editor/tasks - - -## Build from source - -If you’re familiar with TypeScript, the [Theia IDE](https://theia-ide.org/), and if you want to contribute to the -project, you should be able to build the Arduino IDE locally. -Please refer to the [Theia IDE prerequisites](https://github.com/eclipse-theia/theia/blob/master/doc/Developing.md#prerequisites) documentation for the setup instructions. -> **Note**: Node.js 14 must be used instead of the version 12 recommended at the link above. - -Once you have all the tools installed, you can build the editor following these steps - -1. Install the dependencies and build - ```sh - yarn - ``` - -2. Rebuild the dependencies - ```sh - yarn rebuild:browser - ``` - -3. Rebuild the electron dependencies - ```sh - yarn rebuild:electron - ``` - -4. Start the application - ```sh - yarn start - ``` - -### Notes for Windows contributors -Windows requires the Microsoft Visual C++ (MSVC) compiler toolset to be installed on your development machine. - -In case it's not already present, it can be downloaded from the "**Tools for Visual Studio 20XX**" section of the Visual Studio [downloads page](https://visualstudio.microsoft.com/downloads/#build-tools-for-visual-studio-2022) via the "**Build Tools for Visual Studio 20XX**" (e.g., "**Build Tools for Visual Studio 2022**") download link. - -Select "**Desktop development with C++**" from the "**Workloads**" tab during the installation procedure. - -### CI - -This project is built on [GitHub Actions](https://github.com/arduino/arduino-ide/actions). - - - _Snapshot_ builds run when changes are pushed to the `main` branch, or when a PR is created against the `main` branch. For the sake of the review and verification process, the build artifacts for each operating system can be downloaded from the GitHub Actions page. - - _Nightly_ builds run every day at 03:00 GMT from the `main` branch. - - _Release_ builds run when a new tag is pushed to the remote. The tag must follow the [semver](https://semver.org/). For instance, `1.2.3` is a correct tag, but `v2.3.4` won't work. Steps to trigger a new release build: - - Create a local tag: - ```sh - git tag -a 1.2.3 -m "Creating a new tag for the `1.2.3` release." - ``` - - Push it to the remote: - ```sh - git push origin 1.2.3 - ``` - -## Notes for macOS contributors -Beginning in macOS 10.14.5, the software [must be notarized to run](https://developer.apple.com/documentation/xcode/notarizing_macos_software_before_distribution). The signing and notarization processes for the Arduino IDE are managed by our Continuous Integration (CI) workflows, implemented with GitHub Actions. On every push and pull request, the Arduino IDE is built and saved to a workflow artifact. These artifacts can be used by contributors and beta testers who don't want to set up a build system locally. -For security reasons, signing and notarization are disabled for workflow runs for pull requests from forks of this repository. This means that macOS will block you from running those artifacts. -Due to this limitation, Mac users have two options for testing contributions from forks: - -### The Safe approach (recommended) - -Follow [the instructions above](#build-from-source) to create the build environment locally, then build the code you want to test. - -### The Risky approach - -*Please note that this approach is risky as you are lowering the security on your system, therefore we strongly discourage you from following it.* -1. Use [this guide](https://help.apple.com/xcode/mac/10.2/index.html?localePath=en.lproj#/dev9b7736b0e), in order to disable Gatekeeper (at your own risk!). -1. Download the unsigned artifact provided by the CI workflow run related to the Pull Request at each push. -1. Re-enable Gatekeeper after tests are done, following the guide linked above. - -## FAQ - -* *Can I manually change the version of the [`arduino-cli`](https://github.com/arduino/arduino-cli/) used by the IDE?* - - Yes. It is possible but not recommended. The CLI exposes a set of functionality via [gRPC](https://github.com/arduino/arduino-cli/tree/master/rpc) and the IDE uses this API to communicate with the CLI. Before we build a new version of IDE, we pin a specific version of CLI and use the corresponding `proto` files to generate TypeScript modules for gRPC. This means, a particular version of IDE is compliant only with the pinned version of CLI. Mismatching IDE and CLI versions might not be able to communicate with each other. This could cause unpredictable IDE behavior. - -* *I have understood that not all versions of the CLI are compatible with my version of IDE but how can I manually update the `arduino-cli` inside the IDE?* - - [Get](https://arduino.github.io/arduino-cli/installation) the desired version of `arduino-cli` for your platform and manually replace the one inside the IDE. The CLI can be found inside the IDE at: - - Windows: `C:\path\to\Arduino IDE\resources\app\node_modules\arduino-ide-extension\build\arduino-cli.exe`, - - macOS: `/path/to/Arduino IDE.app/Contents/Resources/app/node_modules/arduino-ide-extension/build/arduino-cli`, and - - Linux: `/path/to/Arduino IDE/resources/app/node_modules/arduino-ide-extension/build/arduino-cli`. +# Development Guide +This documentation has been moved [**here**](docs/development.md#development-guide). diff --git a/README.md b/README.md index 324da2691..cb19f42fe 100644 --- a/README.md +++ b/README.md @@ -42,7 +42,7 @@ This repository contains the main code, but two more repositories are included d - [vscode-arduino-tools](https://github.com/arduino/vscode-arduino-tools): provides support for the language server and the debugger - [arduino-language-server](https://github.com/arduino/arduino-language-server): provides the language server that parses Arduino code -See the [BUILDING.md](BUILDING.md) for a technical overview of the application and instructions for building the code. +See the [development guide](docs/development.md) for a technical overview of the application and instructions for building the code. You can help with the translation of the Arduino IDE to your language here: [Arduino IDE on Transifex](https://www.transifex.com/arduino-1/ide2/dashboard/). diff --git a/docs/development.md b/docs/development.md new file mode 100644 index 000000000..2edfd0e59 --- /dev/null +++ b/docs/development.md @@ -0,0 +1,120 @@ +# Development Guide + +This page includes technical documentation for developers who want to build the IDE locally and contribute to the project. + +## Architecture overview + +The IDE consists of three major parts: + - the _Electron main_ process, + - the _backend_, and + - the _frontend_. + +The _Electron main_ process is responsible for: + - creating the application, + - managing the application lifecycle via listeners, and + - creating and managing the web pages for the app. + +In Electron, the process that runs the main entry JavaScript file is called the main process. The _Electron main_ process can display a GUI by creating web pages. An Electron app always has exactly one main process. + +By default, whenever the _Electron main_ process creates a web page, it will instantiate a new `BrowserWindow` instance. Since Electron uses Chromium for displaying web pages, Chromium's multi-process architecture is also used. Each web page in Electron runs in its own process, which is called the renderer process. Each `BrowserWindow` instance runs the web page in its own renderer process. When a `BrowserWindow` instance is destroyed, the corresponding renderer process is also terminated. The main process manages all web pages and their corresponding renderer processes. Each renderer process is isolated and only cares about the web page running in it.[[1]] + +In normal browsers, web pages usually run in a sandboxed environment, and accessing native resources are disallowed. However, Electron has the power to use Node.js APIs in the web pages allowing lower-level OS interactions. Due to security reasons, accessing native resources is an undesired behavior in the IDE. So by convention, we do not use Node.js APIs. (Note: the Node.js integration is [not yet disabled](https://github.com/eclipse-theia/theia/issues/2018) although it is not used). In the IDE, only the _backend_ allows OS interaction. + +The _backend_ process is responsible for: + - providing access to the filesystem, + - communicating with the [Arduino CLI](https://github.com/arduino/arduino-cli) via gRPC, + - running your terminal, + - exposing additional RESTful APIs, + - performing the Git commands in the local repositories, + - hosting and running any VS Code extensions, or + - executing VS Code tasks[[2]]. + +The _Electron main_ process spawns the _backend_ process. There is always exactly one _backend_ process. However, due to performance considerations, the _backend_ spawns several sub-processes for the filesystem watching, Git repository discovery, etc. The communication between the _backend_ process and its sub-processes is established via IPC. Besides spawning sub-processes, the _backend_ will start an HTTP server on a random available port, and serves the web application as static content. When the sub-processes are up and running, and the HTTP server is also listening, the _backend_ process sends the HTTP server port to the _Electron main_ process via IPC. The _Electron main_ process will load the _backend_'s endpoint in the `BrowserWindow`. + +The _frontend_ is running as an Electron renderer process and can invoke services implemented on the _backend_. The communication between the _backend_ and the _frontend_ is done via JSON-RPC over a websocket connection. This means, the services running in the _frontend_ are all proxies, and will ask the corresponding service implementation on the _backend_. + +[1]: https://www.electronjs.org/docs/tutorial/application-architecture#differences-between-main-process-and-renderer-process +[2]: https://code.visualstudio.com/Docs/editor/tasks + + +## Build from source + +If you’re familiar with TypeScript, the [Theia IDE](https://theia-ide.org/), and if you want to contribute to the +project, you should be able to build the Arduino IDE locally. +Please refer to the [Theia IDE prerequisites](https://github.com/eclipse-theia/theia/blob/master/doc/Developing.md#prerequisites) documentation for the setup instructions. +> **Note**: Node.js 14 must be used instead of the version 12 recommended at the link above. + +Once you have all the tools installed, you can build the editor following these steps + +1. Install the dependencies and build + ```sh + yarn + ``` + +2. Rebuild the dependencies + ```sh + yarn rebuild:browser + ``` + +3. Rebuild the electron dependencies + ```sh + yarn rebuild:electron + ``` + +4. Start the application + ```sh + yarn start + ``` + +### Notes for Windows contributors +Windows requires the Microsoft Visual C++ (MSVC) compiler toolset to be installed on your development machine. + +In case it's not already present, it can be downloaded from the "**Tools for Visual Studio 20XX**" section of the Visual Studio [downloads page](https://visualstudio.microsoft.com/downloads/#build-tools-for-visual-studio-2022) via the "**Build Tools for Visual Studio 20XX**" (e.g., "**Build Tools for Visual Studio 2022**") download link. + +Select "**Desktop development with C++**" from the "**Workloads**" tab during the installation procedure. + +### CI + +This project is built on [GitHub Actions](https://github.com/arduino/arduino-ide/actions). + + - _Snapshot_ builds run when changes are pushed to the `main` branch, or when a PR is created against the `main` branch. For the sake of the review and verification process, the build artifacts for each operating system can be downloaded from the GitHub Actions page. + - _Nightly_ builds run every day at 03:00 GMT from the `main` branch. + - _Release_ builds run when a new tag is pushed to the remote. The tag must follow the [semver](https://semver.org/). For instance, `1.2.3` is a correct tag, but `v2.3.4` won't work. Steps to trigger a new release build: + - Create a local tag: + ```sh + git tag -a 1.2.3 -m "Creating a new tag for the `1.2.3` release." + ``` + - Push it to the remote: + ```sh + git push origin 1.2.3 + ``` + +## Notes for macOS contributors +Beginning in macOS 10.14.5, the software [must be notarized to run](https://developer.apple.com/documentation/xcode/notarizing_macos_software_before_distribution). The signing and notarization processes for the Arduino IDE are managed by our Continuous Integration (CI) workflows, implemented with GitHub Actions. On every push and pull request, the Arduino IDE is built and saved to a workflow artifact. These artifacts can be used by contributors and beta testers who don't want to set up a build system locally. +For security reasons, signing and notarization are disabled for workflow runs for pull requests from forks of this repository. This means that macOS will block you from running those artifacts. +Due to this limitation, Mac users have two options for testing contributions from forks: + +### The Safe approach (recommended) + +Follow [the instructions above](#build-from-source) to create the build environment locally, then build the code you want to test. + +### The Risky approach + +*Please note that this approach is risky as you are lowering the security on your system, therefore we strongly discourage you from following it.* +1. Use [this guide](https://help.apple.com/xcode/mac/10.2/index.html?localePath=en.lproj#/dev9b7736b0e), in order to disable Gatekeeper (at your own risk!). +1. Download the unsigned artifact provided by the CI workflow run related to the Pull Request at each push. +1. Re-enable Gatekeeper after tests are done, following the guide linked above. + +## FAQ + +* *Can I manually change the version of the [`arduino-cli`](https://github.com/arduino/arduino-cli/) used by the IDE?* + + Yes. It is possible but not recommended. The CLI exposes a set of functionality via [gRPC](https://github.com/arduino/arduino-cli/tree/master/rpc) and the IDE uses this API to communicate with the CLI. Before we build a new version of IDE, we pin a specific version of CLI and use the corresponding `proto` files to generate TypeScript modules for gRPC. This means, a particular version of IDE is compliant only with the pinned version of CLI. Mismatching IDE and CLI versions might not be able to communicate with each other. This could cause unpredictable IDE behavior. + +* *I have understood that not all versions of the CLI are compatible with my version of IDE but how can I manually update the `arduino-cli` inside the IDE?* + + [Get](https://arduino.github.io/arduino-cli/installation) the desired version of `arduino-cli` for your platform and manually replace the one inside the IDE. The CLI can be found inside the IDE at: + - Windows: `C:\path\to\Arduino IDE\resources\app\node_modules\arduino-ide-extension\build\arduino-cli.exe`, + - macOS: `/path/to/Arduino IDE.app/Contents/Resources/app/node_modules/arduino-ide-extension/build/arduino-cli`, and + - Linux: `/path/to/Arduino IDE/resources/app/node_modules/arduino-ide-extension/build/arduino-cli`. + diff --git a/docs/internal/Arm.md b/docs/internal/Arm.md index 8bcca9db4..f6f1d52aa 100644 --- a/docs/internal/Arm.md +++ b/docs/internal/Arm.md @@ -41,7 +41,7 @@ Building the Pro IDE on Linux `armv7l` (aka `armhf`) and `aarch64` (aka `arm64`) - `libx11-dev`, and - `libxkbfile-dev` -4. [Build it](../../BUILDING.md#build-from-source) from the source: +4. [Build it](../development.md#build-from-source) from the source: ``` git clone https://github.com/arduino/arduino-ide.git \ && cd arduino-ide \ From 450c39211df7dd34940ee04b49d026095728be28 Mon Sep 17 00:00:00 2001 From: per1234 Date: Fri, 9 Sep 2022 21:05:27 -0700 Subject: [PATCH 2/6] Move documentation assets to standard location --- docs/README.md | 4 ++-- docs/{static => assets}/preferences.png | Bin docs/{static => assets}/remote.png | Bin 3 files changed, 2 insertions(+), 2 deletions(-) rename docs/{static => assets}/preferences.png (100%) rename docs/{static => assets}/remote.png (100%) diff --git a/docs/README.md b/docs/README.md index c5d9cf00f..6c6f59479 100644 --- a/docs/README.md +++ b/docs/README.md @@ -1,7 +1,7 @@ # Remote Sketchbook Arduino IDE provides a Remote Sketchbook feature that can be used to upload sketches to Arduino Cloud. -![](static/remote.png) +![](assets/remote.png) @@ -13,7 +13,7 @@ A developer could use the content of this repo to create a customized version of ### 1. Changing remote connection parameters in the Preferences panel (be careful while editing the Preferences panel!) Here a screenshot of the Preferences panel -![](static/preferences.png) +![](assets/preferences.png) - The settings under _Arduino > Auth_ should be edited to match the OAuth2 configuration of your custom remote sketchbook storage - The setting under _Arduino > Sketch Sync Endpoint_ should be edited to point to your custom remote sketchbook storage service ### 2. Implementing the Arduino Cloud Store APIs for your custom remote sketchbook storage diff --git a/docs/static/preferences.png b/docs/assets/preferences.png similarity index 100% rename from docs/static/preferences.png rename to docs/assets/preferences.png diff --git a/docs/static/remote.png b/docs/assets/remote.png similarity index 100% rename from docs/static/remote.png rename to docs/assets/remote.png From 6a04c59a8cd73b9e80660e6386b844594e26ed26 Mon Sep 17 00:00:00 2001 From: per1234 Date: Fri, 9 Sep 2022 21:34:44 -0700 Subject: [PATCH 3/6] Move beta testing information to a dedicated documentation file Previously, the information about tester builds was mixed in with the documentation about building the project from source. The two subjects are of relevance to two distinct contribution options. Building from source will primarily be done by developers working on the project code base. Tester builds will be used by beta testers and reviewers. For this reason, it doesn't make sense to require beta testers to wade through a lot of development documentation not directly related to their work in order to find the instructions for obtaining tester builds. Likewise, it doesn't make sense to clutter up the development documentation with such information. Moving the information about tester builds to a dedicated file makes it easier for the interested parties to find, and also allows the creation of a comprehensive guide for beta testers without making a negative impact on the development documentation content. --- docs/contributor-guide/assets/checks-tab.png | Bin 0 -> 42700 bytes .../assets/tester-build-artifacts.png | Bin 0 -> 17208 bytes .../assets/tester-build-link.png | Bin 0 -> 20961 bytes docs/contributor-guide/beta-testing.md | 106 ++++++++++++++++++ docs/development.md | 22 +--- 5 files changed, 112 insertions(+), 16 deletions(-) create mode 100644 docs/contributor-guide/assets/checks-tab.png create mode 100644 docs/contributor-guide/assets/tester-build-artifacts.png create mode 100644 docs/contributor-guide/assets/tester-build-link.png create mode 100644 docs/contributor-guide/beta-testing.md diff --git a/docs/contributor-guide/assets/checks-tab.png b/docs/contributor-guide/assets/checks-tab.png new file mode 100644 index 0000000000000000000000000000000000000000..ee18549524c988f3f1a9903a61db093f0e542666 GIT binary patch literal 42700 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%0ABU{d()L_ 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 R+ZO-;002ovPDHLkV1g{-fa?GN literal 0 HcmV?d00001 diff --git a/docs/contributor-guide/assets/tester-build-artifacts.png b/docs/contributor-guide/assets/tester-build-artifacts.png new file mode 100644 index 0000000000000000000000000000000000000000..ab9dada84a09a5ab619aab162fee44e2a8b57f36 GIT binary patch literal 17208 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 D(`@%8 literal 0 HcmV?d00001 diff --git a/docs/contributor-guide/beta-testing.md b/docs/contributor-guide/beta-testing.md new file mode 100644 index 000000000..9f4dba110 --- /dev/null +++ b/docs/contributor-guide/beta-testing.md @@ -0,0 +1,106 @@ + + +# Beta Testing Guide + +Beta testing of development versions is a valuable contribution to the project. You can help to ensure the quality of the production release that will be distributed to the user community. + +Builds of the project are automatically created after every relevant change to the project in order to make it easy for anyone to participate in the testing effort. + +--- + +❗ Make sure to always download the newest available tester build in order to ensure effective results from your beta testing efforts. + +--- + +Beta testing is done during both the proposal (pull request) and pre-release (nightly build) phases of development: + +## Testing Pull Requests + +Tester builds are automatically created for every [pull request](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests) (PR) that proposes a relevant change. + +The builds are updated if the author pushes changes to the PR. + +### Installation + +The tester build for a PR can be downloaded by following these instructions: + +1. Sign in to your [**GitHub**](https://github.com/) account.
+ (GitHub only allows downloads of the tester builds when you are signed in.) +1. Open the PR you are interested in.
+ They are listed here:
+ https://github.com/arduino/arduino-ide/pulls +1. Click the "**Checks**" tab at the top of the PR's page. +1. From the list on the left side of the page, click on "**Arduino IDE**". +1. Scroll down to the "**Artifacts**" section of the page that opens. +1. Click the download link for your operating system.
+ **ⓘ** For example, if you are using Windows, click the "**Windows_X86-64_zip**" link. +1. Wait for the download to finish. +1. Extract or install the downloaded file as usual. + +![checks tab](assets/checks-tab.png) + +![tester build link](assets/tester-build-link.png) + +![tester build artifacts](assets/tester-build-artifacts.png) + +#### Notes for macOS + +Beginning in macOS 10.14.5, the software [must be notarized to run](https://developer.apple.com/documentation/xcode/notarizing_macos_software_before_distribution). + +For security reasons, signing and notarization are disabled when creating tester builds for pull requests from forks of this repository. This means that macOS will block you from running the tester builds for those PRs. + +Due to this limitation, Mac users have two options for testing PRs from forks: + +##### The Safe Approach + +Build the version of the Arduino IDE you want to test from source instead of using the automatically created tester build. + +[Instructions for building the project](../development.md#build-from-source) + +##### The Risky Approach + +--- + +⚠ Please note that this approach is risky as you are lowering the security on your system, therefore we strongly discourage you from following it. + +--- + +1. Use [this guide](https://help.apple.com/xcode/mac/10.2/index.html?localePath=en.lproj#/dev9b7736b0e), in order to disable Gatekeeper (at your own risk!). +1. Beta test the tester build. +1. Re-enable Gatekeeper after tests are done, following the guide linked above. + +### Feedback + +Feedback after beta testing a pull request is always valuable, regardless of which categories your findings fall under: + +- working as expected +- problems encountered +- areas for improvement + +Please submit feedback related to the changes made in the pull request as a PR review: + +https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/about-pull-request-reviews + +--- + +If you discover problems or areas for improvement that are unrelated to the changes made by the PR (i.e., they also occur when using the [nightly build](#testing-nightly-build)), please submit that feedback as an issue report instead of a review. + +[More information on issue reports](issues.md#issue-report-guide) + +## Testing Nightly Build + +Builds of the project's production branch are produced daily. This build represents the current pre-release state of the project, which is planned for distribution in the next release. + +### Installation + +1. Open Arduino's "**Software**" page:
+ https://www.arduino.cc/en/software#nightly-builds +1. Select the appropriate download link from the "**Nightly Builds**" section of the page. +1. Wait for the download to finish. +1. Extract or install the downloaded file as usual. + +### Feedback + +If you discover any problems or areas for improvement please submit an issue report. + +[More information on issue reports](issues.md#issue-report-guide) diff --git a/docs/development.md b/docs/development.md index 2edfd0e59..ac8a2e5ed 100644 --- a/docs/development.md +++ b/docs/development.md @@ -39,6 +39,12 @@ The _frontend_ is running as an Electron renderer process and can invoke service ## Build from source +--- + +**ⓘ** If you only want to test an existing version of the project, automatically generated builds are available for download without building from source. See the instructions in the [**beta testing guide**](contributor-guide/beta-testing.md#beta-testing-guide). + +--- + If you’re familiar with TypeScript, the [Theia IDE](https://theia-ide.org/), and if you want to contribute to the project, you should be able to build the Arduino IDE locally. Please refer to the [Theia IDE prerequisites](https://github.com/eclipse-theia/theia/blob/master/doc/Developing.md#prerequisites) documentation for the setup instructions. @@ -89,22 +95,6 @@ This project is built on [GitHub Actions](https://github.com/arduino/arduino-ide git push origin 1.2.3 ``` -## Notes for macOS contributors -Beginning in macOS 10.14.5, the software [must be notarized to run](https://developer.apple.com/documentation/xcode/notarizing_macos_software_before_distribution). The signing and notarization processes for the Arduino IDE are managed by our Continuous Integration (CI) workflows, implemented with GitHub Actions. On every push and pull request, the Arduino IDE is built and saved to a workflow artifact. These artifacts can be used by contributors and beta testers who don't want to set up a build system locally. -For security reasons, signing and notarization are disabled for workflow runs for pull requests from forks of this repository. This means that macOS will block you from running those artifacts. -Due to this limitation, Mac users have two options for testing contributions from forks: - -### The Safe approach (recommended) - -Follow [the instructions above](#build-from-source) to create the build environment locally, then build the code you want to test. - -### The Risky approach - -*Please note that this approach is risky as you are lowering the security on your system, therefore we strongly discourage you from following it.* -1. Use [this guide](https://help.apple.com/xcode/mac/10.2/index.html?localePath=en.lproj#/dev9b7736b0e), in order to disable Gatekeeper (at your own risk!). -1. Download the unsigned artifact provided by the CI workflow run related to the Pull Request at each push. -1. Re-enable Gatekeeper after tests are done, following the guide linked above. - ## FAQ * *Can I manually change the version of the [`arduino-cli`](https://github.com/arduino/arduino-cli/) used by the IDE?* From d1261a7b9436d7a45012de860e0980d974b7b7f9 Mon Sep 17 00:00:00 2001 From: per1234 Date: Sat, 10 Sep 2022 02:37:29 -0700 Subject: [PATCH 4/6] Add a project contributor guide Documentation of how to contribute to the project gives everyone the opportunity to participate, while also reducing the maintenance effort and increasing the quality of contributions. This guide documents the various ways of contributing to the project. --- .github/ISSUE_TEMPLATE/config.yml | 6 + docs/CONTRIBUTING.md | 29 ++++ docs/contributor-guide/assets/checks.png | Bin 0 -> 40075 bytes docs/contributor-guide/beta-testing.md | 2 +- docs/contributor-guide/issues.md | 33 ++++ docs/contributor-guide/pull-requests.md | 199 +++++++++++++++++++++++ 6 files changed, 268 insertions(+), 1 deletion(-) create mode 100644 docs/CONTRIBUTING.md create mode 100644 docs/contributor-guide/assets/checks.png create mode 100644 docs/contributor-guide/issues.md create mode 100644 docs/contributor-guide/pull-requests.md diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml index 00769ec0d..e87427856 100644 --- a/.github/ISSUE_TEMPLATE/config.yml +++ b/.github/ISSUE_TEMPLATE/config.yml @@ -8,6 +8,12 @@ contact_links: - name: Support request url: https://forum.arduino.cc/ about: We can help you out on the Arduino Forum! + - name: Issue report guide + url: https://github.com/arduino/arduino-ide/blob/main/docs/issues.md#issue-report-guide + about: Learn about submitting issue reports to this repository. + - name: Contributor guide + url: https://github.com/arduino/arduino-ide/blob/main/docs/CONTRIBUTING.md#contributor-guide + about: Learn about contributing to this project. - name: Discuss development work on the project url: https://groups.google.com/a/arduino.cc/g/developers about: Arduino Developers Mailing List diff --git a/docs/CONTRIBUTING.md b/docs/CONTRIBUTING.md new file mode 100644 index 000000000..72e6a6e36 --- /dev/null +++ b/docs/CONTRIBUTING.md @@ -0,0 +1,29 @@ + + +# Contributor Guide + +Thanks for your interest in contributing to this project! + +There are several ways you can get involved: + +| Type of contribution | Contribution method | +| ----------------------------------------- | -------------------------------------------------------------------------------- | +| - Support
- Question
- Discussion | Post on the [**Arduino Forum**][forum] | +| - Bug report
- Feature request | Issue report (see the guide [**here**][issues]) | +| Testing | Beta testing, PR review (see the guide [**here**][beta-testing]) | +| Translation | [Transifex project][translate] | +| - Bug fix
- Enhancement | Pull request (see the guide [**here**][prs]) | +| Monetary | - [Donate][donate]
- [Sponsor][sponsor]
- [Buy official products][store] | + +[forum]: https://forum.arduino.cc +[issues]: contributor-guide/issues.md#issue-report-guide +[beta-testing]: contributor-guide/beta-testing.md#beta-testing-guide +[translate]: https://www.transifex.com/arduino-1/ide2/dashboard/ +[prs]: contributor-guide/pull-requests.md#pull-request-guide +[donate]: https://www.arduino.cc/en/donate/ +[sponsor]: https://github.com/sponsors/arduino +[store]: https://store.arduino.cc + +## Resources + +- [**Development Guide**](development.md#development-guide) diff --git a/docs/contributor-guide/assets/checks.png b/docs/contributor-guide/assets/checks.png new file mode 100644 index 0000000000000000000000000000000000000000..888e711b4a2ea0c64d0e470aa4997c0c21ecaa59 GIT binary patch literal 40075 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

W`+0NwJpCYq|gkp3MnG?=k~g0**X^r20} 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 + # Beta Testing Guide diff --git a/docs/contributor-guide/issues.md b/docs/contributor-guide/issues.md new file mode 100644 index 000000000..6fdb9ea8c --- /dev/null +++ b/docs/contributor-guide/issues.md @@ -0,0 +1,33 @@ + + +# Issue Report Guide + +--- + +❗ Do you need help or have a question about using this project? Support requests should be made to the [Arduino Forum](https://forum.arduino.cc). + +--- + +High quality bug reports and feature requests are valuable contributions to this project. These can be made by submitting an issue report to the project's GitHub repository: + +https://github.com/arduino/arduino-ide/issues/new/choose + +## Before Reporting an Issue + +- Give the latest development version a test drive to see if your issue was already resolved:
+ https://www.arduino.cc/en/software#nightly-builds +- Search [existing pull requests and issues](https://github.com/arduino/arduino-ide/issues?q=) to see if it was already reported.
+ If you have additional information to provide about an existing issue, please comment there instead of creating a duplicate. You can use [GitHub's "Reactions" feature](https://github.blog/2016-03-10-add-reactions-to-pull-requests-issues-and-comments/) if you only want to express support 👍. + +## Qualities of an Excellent Report + +- Concise and descriptive issue title.
+ Vague titles make it difficult to decipher the purpose of the issue when looking through the list of reports, which might result in your issue not being given proper attention. +- Describe the issue and what behavior you were expecting.
+ Include the full and exact text of any relevant error or warning messages you might have encountered. +- Provide a full set of steps necessary to reproduce the issue.
+ Demonstration code or commands should be complete and simplified to the minimum necessary to reproduce the issue. +- Be responsive.
+ We may need you to provide additional information in order to investigate and resolve the issue.
+ Make sure your GitHub account is configured so that you will receive notifications of responses to your issue report. +- If you find a solution to your problem, please comment on your issue report with an explanation of how you were able to fix it, then close the issue. diff --git a/docs/contributor-guide/pull-requests.md b/docs/contributor-guide/pull-requests.md new file mode 100644 index 000000000..6c3d29b23 --- /dev/null +++ b/docs/contributor-guide/pull-requests.md @@ -0,0 +1,199 @@ + + +# Pull Request Guide + +A [**pull request**](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests) (PR) is the mechanism used to propose changes to the content of this project's repository. + +If you are looking for ideas of what to work on, check [the list of open issue reports](https://github.com/arduino/arduino-ide/issues). Pull requests addressing any of those bug reports and feature requests are welcome. + +## Contribution Workflow + +Each contribution travels through a formal process which allows it to be efficiently incorporated into the project. + +### 1. Plan + +#### Research + +Start by searching the repository for existing pull requests and issues related to your planned contribution so you can see any related conversations and proposals and avoid duplicate effort: + +https://github.com/arduino/arduino-ide/issues?q= + +#### Discussion + +It can sometimes be useful to get feedback from others during the planning process. There are a couple good options for discussing planned development work: + +- Talk with the user community on the [Arduino Forum](https://forum.arduino.cc/). +- Talk with Arduino developers on the [Arduino Developers Mailing List](https://groups.google.com/a/arduino.cc/g/developers). + +### 2. Fork + +Forking a GitHub repository creates a copy of it under your account. You will stage contributions in your fork of this project. + +[More information about forking repositories](https://docs.github.com/get-started/quickstart/fork-a-repo) + +#### Enabling CI in Your Fork + +The repository is configured to run automated [continuous integration](https://wikipedia.org/wiki/Continuous_integration) (CI) checks and tests. It's a good idea to enable CI in your fork so you can make sure your work will pass the checks before you submit a pull request: + +1. Open the homepage of your fork in the browser. +1. Click the "**Actions**" tab. +1. Click the **I understand my workflows, go ahead and enable them** button. +1. Some of the workflows will now need to be activated individually. Perform the following steps for each of the useful workflows listed on the left side of the page that have a "**!**" icon: + 1. Click on the workflow name. + 1. Click the **Enable workflow** button. + +### 3. Clone + +Cloning a repository creates a copy of it on your computer. + +It is possible to make simple changes to your repository using the GitHub web interface without cloning the repository. However, the GitHub web interface is quite limiting so you will likely find the need to work with a clone (using **Git** directly or your choice of [Git client software](https://git-scm.com/downloads/guis)) for any significant development work. + +[More information about cloning repositories](https://git-scm.com/docs/git-clone) + +### 4. Branch + +Create a branch in your fork to contain the changes for your contribution. You must make a separate branch in your fork for each pull request you submit. + +[More information about branches](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-branches) + +### 5. Make a change + +Some things to keep in mind: + +- Make sure your change complies with the project's established style conventions. +- Remember to also update the documentation content in the repository if required by your changes. +- If the project contains a test suite, update or add tests according to your change as appropriate. + +See [the development guide](../development.md#development-guide) for more information. + +### 6. Test + +Test your change carefully to make sure it works correctly and did not break other components of the project. + +As a supplement for general testing, the project is set up with automated checks and tests to facilitate development. + +See [the development guide](../development.md#development-guide) for instructions. + +### 7. Commit + +Once the work on your change is complete, add it to the revision history of the Git repository by making a commit. + +Make sure to follow the [Commit Guidelines](#commit-guidelines). + +[More information about commits](https://git-scm.com/docs/git-commit) + +### 8. Push + +If you're working from a [clone](#3-clone), you will need to push your commit to your fork on GitHub. + +[More information about pushing commits](https://git-scm.com/docs/git-push) + +#### Checking CI Results + +If you have [enabled CI in your repository](#enabling-ci-in-your-fork), GitHub will run the relevant checks automatically every time you push a commit to your fork. + +You can see the results of these checks by doing either of the following: + +- Clicking the status icon (✔️ or ❌) shown to the right of a commit. +- Opening the repository's "**Actions**" tab. + +### 9. Pull request + +A pull request (PR) is a proposal to make a change in a repository. The repository maintainer is able to accept the changes you propose in a pull request by simply clicking a button. + +[More information about pull requests](https://docs.github.com/pull-requests/collaborating-with-pull-requests/proposing-changes-to-your-work-with-pull-requests/about-pull-requests) + +#### Scope + +Each pull request should address a single bug fix or enhancement. If you have multiple unrelated fixes or enhancements to contribute, submit them as separate pull requests. + +#### Description + +Pull request title and description should follow [the same guidelines as commit messages](#commit-message). + +If your pull request fixes an issue in the issue tracker, use [a closing keyword](https://docs.github.com/issues/tracking-your-work-with-issues/linking-a-pull-request-to-an-issue#linking-a-pull-request-to-an-issue-using-a-keyword) in the body to indicate this. + +In some cases, it might make sense to request feedback on a proposal before it is ready to be merged. You can indicate this by starting the pull request title with **[WIP]** (work in progress). Once the pull request is ready to be merged, edit the title and remove the "[WIP]". + +#### Cross-repository Contributions + +Some proposals may require changes to multiple repositories. Pull requests should be submitted in parallel to each repository. + +Clearly note any dependencies on other PRs in the description so that these can be evaluated by the reviewer and the merges coordinated. + +--- + +Please check whether any changes are required to the related documentation content hosted in the separate dedicated repositories: + +- [**arduino/docs-content**](https://github.com/arduino/docs-content) +- [**arduino/help-center-content**](https://github.com/arduino/help-center-content) + +### 10. Resolve CI failures + +Relevant checks will run automatically once you have submitted the pull request. Once these checks are finished, you can see a summary of the results near the bottom of the pull request page: + +![checks](assets/checks.png) + +Failed checks will be indicated with an ❌. If any checks failed, please fix whatever caused it to fail. Click the "**Details**" link to the right of the check name to open the logs, which provide details about the failure. + +--- + +**ⓘ** In some rare cases, a CI failure may be unrelated to the changes made in your pull request. So if the information in the logs doesn't seem relevant, please comment on the pull request to ask a maintainer to take a look. + +--- + +When you push to the branch of your fork the pull request was submitted from, the commit is automatically added to the pull request. Don't create a new pull request to fix problems; update the existing pull request. + +### 11. Resolve changes requested from reviews + +Interested parties may review your pull request and suggest improvements. + +To act on general review suggestions, you can add commits to the branch you submitted the pull request from, which will automatically be added to the pull request. Don't create a new pull request to act on review suggestions; update the existing pull request. + +Reviewers may suggest specific changes, which can be applied by [clicking the **Commit suggestion** button](https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/incorporating-feedback-in-your-pull-request#applying-suggested-changes). + +[More information about pull request reviews](https://docs.github.com/pull-requests/collaborating-with-pull-requests/reviewing-changes-in-pull-requests/about-pull-request-reviews) + +### 12. Merge + +One of the repository maintainers can now choose to accept your proposed change. Once the pull request is [merged](https://docs.github.com/pull-requests/collaborating-with-pull-requests/incorporating-changes-from-a-pull-request/merging-a-pull-request), you can delete the branch you created in your fork for the pull request and delete the fork as well if you like. + +Thanks so much for your contribution! + +--- + +It is possible that the maintainers may decide a pull request doesn't align with Arduino's goals for the project and close it rather than merging. A record of the proposed changes will always be available on GitHub for future reference. If you think your modifications will be of use to others, you are welcome to maintain your own fork of the repository. + +--- + +## Commit Guidelines + +The commit history of a repository is an important resource for developers. Repositories may accumulate thousands of commits over the course of decades. Each individual commit contributes either to the commit history being pleasant and efficient to work with, or to it being a confusing mess. For this reason, it's essential for contributors to create clean, high quality commits. + +### Scope + +Commits must be "atomic". This means that the commit completely accomplishes a single task. Each commit should result in fully functional code. Multiple tasks should not be combined in a single commit, but a single task should not be split over multiple commits (e.g., one commit per file modified is not a good practice). + +[More information about atomic commits](https://www.freshconsulting.com/insights/blog/atomic-commits/) + +### Commit Message + +The commit message documents what the change was and why it was done. A little effort now writing a good commit message can save future developers from wasted time and frustration trying to understand the purpose of a poorly documented commit. + +#### Commit Message Title + +- Use the [imperative mood](https://cbea.ms/git-commit/#imperative) in the title.
+ For example: + > Use LED_BUILTIN macro in LED pin definition +- Capitalize the title. +- Do not end the title with punctuation. +- Do not use GitHub's default commit titles (e.g., "Update examples/Foo/Foo.ino"). + +#### Commit Message Body + +- Separate title from the body with a blank line. If you're committing via GitHub or [GitHub Desktop](https://desktop.github.com/) this will be done automatically. +- Wrap body at 120 characters. +- Completely explain the purpose of the commit.
+ Include a rationale for the change, any caveats, side-effects, etc. + +[More information on commit messages](https://cbea.ms/git-commit/) From 1cb6515382c777d911a62d73132c16e131eb245c Mon Sep 17 00:00:00 2001 From: per1234 Date: Sat, 10 Sep 2022 03:02:31 -0700 Subject: [PATCH 5/6] Reduce overlap between readme and development+contributor guides The readme should provide a concise overview of the essential information about the project. Additional details are provided in dedicated documents, so the readme only needs to provide links to that information. --- README.md | 18 ++++++++---------- docs/development.md | 6 ++++++ 2 files changed, 14 insertions(+), 10 deletions(-) diff --git a/README.md b/README.md index cb19f42fe..4297eea3d 100644 --- a/README.md +++ b/README.md @@ -20,10 +20,9 @@ If you need assistance, see the [Help Center](https://support.arduino.cc/hc/en-u ## Bugs & Issues -If you want to report an issue, you can submit it to the [issue tracker](https://github.com/arduino/arduino-ide/issues) of this repository. A few rules apply: +If you want to report an issue, you can submit it to the [issue tracker](https://github.com/arduino/arduino-ide/issues) of this repository. -- Before posting, please check if the same problem has been already reported by someone else to avoid duplicates. -- Remember to include as much detail as you can about your hardware set-up, code and steps for reproducing the issue. Make sure you're using an original Arduino board. +See [**the issue report guide**](docs/contributor-guide/issues.md#issue-report-guide) for instructions. ### Security @@ -35,16 +34,15 @@ e-mail contact: security@arduino.cc ## Contributions and development -Contributions are very welcome! You can browse the list of open issues to see what's needed and then you can submit your code using a Pull Request. Please provide detailed descriptions. We also appreciate any help in testing issues and patches contributed by other users. +Contributions are very welcome! There are several ways to participate in this project, including: -This repository contains the main code, but two more repositories are included during the build process: +- Fixing bugs +- Beta testing +- Translation -- [vscode-arduino-tools](https://github.com/arduino/vscode-arduino-tools): provides support for the language server and the debugger -- [arduino-language-server](https://github.com/arduino/arduino-language-server): provides the language server that parses Arduino code +See [**the contributor guide**](docs/CONTRIBUTING.md#contributor-guide) for more information. -See the [development guide](docs/development.md) for a technical overview of the application and instructions for building the code. - -You can help with the translation of the Arduino IDE to your language here: [Arduino IDE on Transifex](https://www.transifex.com/arduino-1/ide2/dashboard/). +See the [**development guide**](docs/development.md) for a technical overview of the application and instructions for building the code. ## Donations diff --git a/docs/development.md b/docs/development.md index ac8a2e5ed..b3146acae 100644 --- a/docs/development.md +++ b/docs/development.md @@ -36,6 +36,12 @@ The _frontend_ is running as an Electron renderer process and can invoke service [1]: https://www.electronjs.org/docs/tutorial/application-architecture#differences-between-main-process-and-renderer-process [2]: https://code.visualstudio.com/Docs/editor/tasks +### Additional Components + +This repository contains the main code, but two more repositories are included during the build process: + +- [vscode-arduino-tools](https://github.com/arduino/vscode-arduino-tools): provides support for the language server and the debugger +- [arduino-language-server](https://github.com/arduino/arduino-language-server): provides the language server that parses Arduino code ## Build from source From eb6fe4f3b720af7acb86014c2a7acc7a2cc088bc Mon Sep 17 00:00:00 2001 From: per1234 Date: Thu, 15 Sep 2022 05:36:40 -0700 Subject: [PATCH 6/6] Make instructions re: non-notarized PR tester build more user friendly For security reasons, the macOS tester builds generated for PRs from forks are not notarized. Instructions are provided for beta testing under these conditions. Previously, the instructions for bypassing the macOS notarization requirement involved disabling macOS Gatekeeper entirely using the spctl command. These instructions are hereby replaced by an alternative approach, where the restriction is bypassed for the Arduino IDE application alone, via the macOS GUI. The new approach is superior for the following reasons: - More secure due to having limited scope - More accessible due to the use of the macOS GUI --- docs/contributor-guide/beta-testing.md | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/docs/contributor-guide/beta-testing.md b/docs/contributor-guide/beta-testing.md index 4c1541289..487713f28 100644 --- a/docs/contributor-guide/beta-testing.md +++ b/docs/contributor-guide/beta-testing.md @@ -65,9 +65,11 @@ Build the version of the Arduino IDE you want to test from source instead of usi --- -1. Use [this guide](https://help.apple.com/xcode/mac/10.2/index.html?localePath=en.lproj#/dev9b7736b0e), in order to disable Gatekeeper (at your own risk!). -1. Beta test the tester build. -1. Re-enable Gatekeeper after tests are done, following the guide linked above. +1. Start the tester build.
+ A warning will appear: + > "Arduino IDE" cannot be opened because the developer cannot be verified. +1. Follow the instructions from the "**If you want to open an app that hasn't been notarized or is from an unidentified developer**" section of this page to bypass the security restriction:
+ [https://support.apple.com/en-us/HT202491](https://support.apple.com/en-us/HT202491#:~:text=If%20you%20want%20to%20open%20an%20app%20that%20hasn%E2%80%99t%20been%20notarized%20or%20is%20from%20an%20unidentified%20developer) ### Feedback