- About The Project
- Getting Started Building a Local Deployment of the Labs Practices Site
- Troubleshooting
- Open Projects, Issues, and Content Backlog
- Contributing
- Code of Conduct
- Labs Practices Site Open Source License
The Labs Practices Site is a site specifically built to be a great resource for software development teams. The contributions on the Labs Practices Site are from teams across Pivotal, VMware, Broadcom, as well as individuals not associated with those organizations.
Our guiding principle is to ensure readers have free, immediate access to all the content on the Labs Practices Site. No purchase is ever necessary to access content on the Labs Practices Site because it is either open source or an easily accessible trial.
git clone --recurse-submodules https://github.com/joemoore/labs-practices-site.git
These options help speed up the repo setup by initializing submodules during the clone process.
There are two available options for building and running a local preview of the Labs Practices Site:
The Dev Container is offered to simplify a local environment setup for those working with and contributing to the Labs Practices Site.
This method requires the following software be installed:
- GNU make (Note:
make
should be available on a Mac with Xcode dev tools installed. Linux users can use their distribution's application manager (e.g. apt install make) or follow the manual steps specified by make. Windows requires special installation to use make.) - Docker (Testing was done with docker desktop installed via
brew install --cask docker
)
An alternative option if make is unavailable is to utilize docker
cli commands to setup the dev-container and work with make
from there.
(Note: The docker daemon must be running):
make dev-container
This will connect to a bash shell in the container immediately after it has finished the build process.
The default working directory in the shell will be the Labs Practices Site git repo directory (it is mounted as a volume in the container). All file edits/additions made from within the container are persistent and saved on the host system.
The container is configured to replicate a fully functional local developer setup.
From within the Dev Container shell prompt, run make help
to see a list of available actions.
The Makefile includes several actions to interact with the dev container. All of the commands are in the following format:
make dev-container.<action>
Use make help
to see the full list of actions
Some examples:
make dev-container.pr-test # Simulates all github pull request checks using the container in docker and act
make dev-container.shell # Starts the container and connects to a bash shell
From the container shell, a preview of the site can be built using:
make preview
These are the software prerequisites needed to build a local preview of the Labs Practices Site site.
Note: These instructions were designed for Mac users. Linux and Windows users without access to make
and brew
will need to manually install the prerequisites.
-
Install Hugo — The Labs Practices Site uses Hugo to build the site from Markdown files. You'll need to get Hugo if you want to build and run the site locally. Make sure you install the extended version with support for SCSS/SASS. This site pins
hugo
to a specific version (currently 0.107.0) to build so if you're using a different version, your experience may vary. To installhugo
, follow the instructions for your specific environment as detailed in the hugo documentation. Ultimately, you have two main options:- Download the correct extended binary for your OS from gohugo GitHub releases page for 0.107.0 and then move the
hugo
binary to an appropriate location (ie.sudo cp hugo /usr/local/bin
) and/or add it to yourPATH
. - Use
brew install hugo
andbrew pin hugo
to pin it to the correct version (0.107.0). (MacOS only.)
- Download the correct extended binary for your OS from gohugo GitHub releases page for 0.107.0 and then move the
-
Install Node (and NPM) — Certain features of the site require Node in order to build (PostCSS, Autoprefixer, etc.), and the Node Package Manager (npm) is also used to manage local packages. If you don’t already have Node installed, you’ll need it in order to build the site. Though it may work with different versions, you should use the same ones that Netlify does, which are Node 16 (as defined in the .nvmrc file at the root) and npm 8 (the corresponding version that comes with Node 16). You may download and install Node or use
brew
to install it:brew install node@16
Note: The reason the .nvmrc is required even though the default should already be v16 for default image that Netlify is set to use - Ubuntu Focal 20.04 - when the site repository was originally linked Netlify, it was using an older image that defaulted to v12, so it must be specified explicitly in the .nvmrc file. (See this article for more details.
-
Install act — The Labs Practices Site uses GitHub Actions to perform automated testing periodically, and on pull requests. If you plan to run these tests locally, you will need
act
. Follow these instructions to installact
, or usebrew
:brew install act
-
Install Docker — The
act
tool depends upon Docker to build images for local automated tests. You can download Docker Desktop or usebrew
:brew install docker --cask
Note: Mac OS X requires Docker Desktop 2.4 or later
With all the dependencies installed, use make help
to see the available actions.
With the change with how the theme files are overridden, the first time you update your branch you may see the following issue when running make preview
:
git submodule update --init --recursive
Submodule 'themes/docsy' (https://github.com/google/docsy.git) registered for path 'themes/docsy'
fatal: not a git repository: /private/tmp/tanzu-dev-portal/themes/docsy/../../.git/modules/themes/docsy
Failed to clone 'themes/docsy'. Retry scheduled
BUG: submodule considered for cloning, doesn't need cloning any more?
fatal: could not get a repository handle for submodule 'themes/docsy'
make: *** [theme] Error 1
You can run the following command for a one-time fix:
make clean-submodule
This is due to the number of files that are opened during the process of building the site. If you're on OSX, this can be addressed with the following command:
sudo launchctl limit maxfiles 65535 200000
ulimit -n 65535
sudo sysctl -w kern.maxfiles=100000
sudo sysctl -w kern.maxfilesperproc=65535
On Windows, you may need to use hugo server -D
to start the application. The site will then be available on http://localhost:1313/
See the open issues and project boards for a list of proposed features, content backlog, and known issues.
Content contributions are what make open source and the developer community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.
The code contribution process is documented in CONTRIBUTING.md.
The content contribution process is documented fully on our GitHub wiki site.
We, the Admin team of the Labs Practices Site adhere to a code of conduct available here: CODE_OF_CONDUCT.md.
The Labs Practices Site is distributed under the Apache License. For more information, see LICENSE.