Updated Troubleshooting issues with samples (markdown)

Hugo Bernier 2022-03-12 16:14:42 -05:00
parent 2e9ab68abd
commit 79f5fcca25
1 changed files with 112 additions and 10 deletions

@ -4,14 +4,116 @@ This article should help you resolve the majority of issues, starting with the m
Once you have performed the steps in this article, you can proceed with creating an issue -- but make sure to read [how to create good issues](How-to-create-good-issues) first, because the people who support these samples are all volunteers, and we certainly want to be respectful of their time, *don't we*?
```mermaid
graph TD;
A-->B;
A-->C;
B-->D;
C-->D;
```
## Most likely cause: Node.js incompatibility
## Sample won't build
Every version of SPFx can be compatible with a different version of Node.js. If you run into an issue with `npm install`, `gulp serve`, `gulp build`, or any other `gulp` commands,
Please refer to the [SPFx Compatibility Matrix](https://docs.microsoft.com/en-us/sharepoint/dev/spfx/compatibility) to make sure that you're using a version of Node.js that is compatible with the version of SPFx the sample uses.
![Symptoms: Won't build](https://img.shields.io/badge/Symptoms-Won%27t%20build-critical?style=for-the-badge&logo=nodedotjs)
### Most likely cause: Node.js incompatibility
Every version of SPFx can be compatible with a different version of Node.js. If you run into an issue with `npm install`, `gulp serve`, `gulp build`, or any other `gulp` commands, it is most likely because the environment you are using to run the sample is not compatible with the sample itself.
You can see a full list of SPFx versions and the supported environment in the [SPFx Compatibility Matrix](https://docs.microsoft.com/en-us/sharepoint/dev/spfx/compatibility).
Every sample's `README.md` file contains a **Compatibility** section, indicating the version of **SPFx** and the **Node.js** version compatibility for that sample.
Look for visual tags such as these:
![SPFx 1.12.1](https://img.shields.io/badge/SPFx-1.12.1-green.svg)
![Node.js v14 | v12 | v10](https://img.shields.io/badge/Node.js-v14%20%7C%20v12%20%7C%20v10-green.svg)
The **SPFx** version indicates which version of the SPFx Yeoman generator was used to build the sample. It *does not need to match the version of the generator currently installed on your workstation* -- unless you are trying to add new SPFx components to the sample (something that you should only consider *after* you get the solution to build successfully).
The **Node.js** version shows the possible major versions that are expected to be compatible with the version of SPFx used. Your current version of Node.js *must* match one of the versions listed in the `README.md`'s compatibility section.
You can determine the version of Node.js on your workstation by running the following command from your workstation's command prompt, Node.js command prompt, or PowerShell:
```dos
node -v
```
The version returned should match the following pattern:
`v##.##.##`
Where the first 2 digits (immediately after the `v`) should match one of the versions listed in the `README.md`'s compatibility section.
> Note: if running `node -v` causes an error, your workstation is most likely not configured as an SPFx development workstation. Please refer to [the workstation configuration steps](https://docs.microsoft.com/sharepoint/dev/spfx/set-up-your-development-environment) before continuing any further.
### Run `spfx doctor`
The easiest way to make sure that your workstation is correctly configured to use the sample is to use the [CLI for Microsoft 365](https://pnp.github.io/cli-microsoft365/) `spfx doctor` from within the sample solution's root folder.
> **Tip:** To easily run the commands in the root folder of the sample solution, try opening the folder with Visual Studio Code, and hit <kbd>CTRL</kbd>+<kbd>\`</kbd> (or <kbd>CTRL</kbd>+<kbd>Shift</kbd>+<kbd>`</kbd> to open a brand new terminal)
To do so, follow these steps:
1. **If you do not have the [CLI for Microsoft 365](https://pnp.github.io/cli-microsoft365/) installed**, install it now; it is a command-line utility that is not required to build SPFx solutions, but is extremely useful. Using your command prompt, enter the following command:
```bash
npm i -g @pnp/cli-microsoft365
```
**If you already have the CLI for Microsoft 365 installed**, make sure that you have the latest version installed by running the following command using your command prompt:
```bash
m365 version
```
If you need to update, you should see a message providing you the instructions to do so:
![CLI message telling you to upgrade](https://user-images.githubusercontent.com/13972467/158033966-6208ed86-e8d6-4c9d-9bde-b774187717d0.png)
The steps to upgrade the CLI are the same as the steps to install:
```bash
npm i -g @pnp/cli-microsoft365
```
1. With the CLI installed, change your command prompt's current directory to the root of the sample's solution. Although it is often the same folder containing the `README.md`, some more complex samples may have multiple solutions in multiple sub-folders. The root will contain a `package.json`.
You can confirm that you are within the solution's root folder by using your command prompt to enter the following command:
```bash
ls package.json
```
If it returns a single `package.json`, you are in the right folder. If you get `ls: cannot access 'package.json': No such file or directory`, make sure to change the current folder (using `cd `, followed by the full path of where your sample is stored).
1. Using your command prompt, enter the following command:
```bash
m365 spfx doctor -o text
```
The command will analyze your environment against the solution. You should see results that begin with the following text:
CLI for Microsoft 365 SharePoint Framework doctor
Verifying configuration of your system for working with the SharePoint Framework
1. If your environment is configured correctly, you will get a series of checkmarks (`√`), for example:
√ SharePoint Framework v1.13.1
√ Node v12.20.2
√ yo v4.3.0
√ gulp v4.0.2
However, if there are any issues with environment compatibility, you will get one or more `×`, for example:
× react v10.8.5 found, v16.9.51 required
1. If you received one or more checkmarks, follow the **Recommended fixes:** generated by `spfx doctor`. For example:
Recommended fixes:
- npm i react@16.9.51
1. Follow each recommended fixes and repeat the `spfx doctor` command until you can confirm that your environment is compatible with the sample.
### Alternatives
#### Recommended
If you are unable to update your environment to run the solution, consider the following alternatives:
- [Open the sample in a remote container](https://github.com/pnp/sp-dev-fx-webparts/wiki/Opening-a-sample-using-a-development-container)
- Use NVM
#### Not recommended
- **Upgrade the sample:** You may be tempted to upgrade the sample to the latest version of SPFx, but doing so may take some time and you may find out that the sample no longer works, or does not meet your needs. Furthermore, you may introduce new bugs that were previously not found in the original version. You should only invest the time to upgrade a sample if you can confirm that the sample works in within a compatible environment, and if you need to add new capabilities that are not supported in previous versions of SPFx, or to fix a vulnerability which can only be fixed with newer versions of SPFx, Node.js, or solution dependencies.