diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000..9ac43cf --- /dev/null +++ b/.editorconfig @@ -0,0 +1,28 @@ +# Root .editorconfig for ronn-ng repo + +# EditorConfig is awesome: https://EditorConfig.org + +root = true + +# This projet is generally a 2-space-indent one. + +# TODO: Use explicit, limited list of extensions to avoid setting any controls +# for test fixture files like .html, .ronn, and .roff? +# [*.{rb,ru,sh,yml,md}] +[*] +end_of_line = lf +indent_style = space +indent_size = 2 +tab_width = 4 +insert_final_newline = true +trim_trailing_whitespace = true +charset = utf-8 + +[Makefile] +indent_style = tab +indent_size = 4 + +# Test fixture text should remain exactly as is. +[test/**] +insert_final_newline = false +trim_trailing_whitespace = false diff --git a/devkit/install-fedora-deps.sh b/devkit/install-fedora-deps.sh new file mode 100755 index 0000000..84c530c --- /dev/null +++ b/devkit/install-fedora-deps.sh @@ -0,0 +1,39 @@ +#!/bin/bash +# +# install-fedora-deps - install Fedora dependencies for Ronn-NG +# +# This installs the RPM packages which Fedora uses as dependencies for Ronn-NG to supply +# its gem dependencies. This is an alternative to installing them with bundler, and lets +# you test Ronn-NG's source in this repo against the system gem packages it will use when +# built in to an RPM. +# +# This does not install the ronn-ng package (rubygem-ronn) itself, to avoid contaminating +# tests of the local Ronn-NG code in this repo with inconsistent versions loaded from the +# system-installed gems. + +pkg_deps=(ruby rubygems-devel rubygem-test-unit + rubygem-kramdown rubygem-kramdown-parser-gfm + rubygem-mustache rubygem-nokogiri) +pkg_anti_deps=(rubygem-ronn-ng rubygem-ronn) + +echo "Installing dep dnf pkgs: ${pkg_deps[@]}" +echo +sudo dnf install -y "${pkg_deps[@]}" + +# Check that the anti-dependencies (main or conflicting code) are not installed +antis_shown=0 +for pkg in "${pkg_anti_deps[@]}"; do + if dnf list installed | cut -d ' ' -f 1 | grep -x "${pkg}.noarch" &> /dev/null; then + if [[ $antis_shown == 0 ]]; then + antis_shown=1 + echo + fi + echo "WARNING: anti-dep pkg ${pkg} is installed, and may interfere with testing" + fi +done +if [[ $antis_shown == 1 ]]; then + echo +fi + +echo "Done." +echo diff --git a/doc-project/Developer-Guide.md b/doc-project/Developer-Guide.md index 59c0257..f6b5661 100644 --- a/doc-project/Developer-Guide.md +++ b/doc-project/Developer-Guide.md @@ -36,7 +36,9 @@ TODO: Add instructions for prerelease/beta releases. Include a process for makin You need to have all of the gem dependencies installed, either in your system gem installation location, or user gems, or locally in this directory. `bundle install` will do something like that, but I haven't been able to figure out how to get that to work with `bundle exec rake test` without requiring you to install the gems and stuff in to the system location instead of a user or dir-local location. -The system Rubies in some OSes, especially macOS, are not suitable for doing Ruby development. Those are for the system's use. You'll need to set up a Ruby development environment. As of 2024-01, I'm using rbenv to create Ruby dev envs, and bundler on top of that to install the gems. Other Ruby env managers may well work, but I don't know them, and don't support them. The docs here assume that you're using rbenv the same way I am. +The system Rubies in some OSes, especially macOS, are not well suited for doing Ruby development. Those are more for the system's use. You'll need to set up a Ruby development environment. On the other hand, you may want to do testing against the system Ruby, for scenarios like Fedora RPMs where they ship a ronn-ng package that uses system-supplied gem dependencies. + +As of 2024-01, I'm using rbenv to create Ruby dev envs, and bundler on top of that to install the gems. Other Ruby env managers may well work, but I don't know them, and don't support them. The docs here assume that you're using rbenv the same way I am. To set up a Ruby dev env for Ronn-NG in the manner that I use: @@ -58,7 +60,7 @@ The `ronn-ng.gemspec` file uses pretty loose dependency version definitions, so * [Ruby setup on macOS](https://www.moncefbelyamani.com/the-definitive-guide-to-installing-ruby-gems-on-a-mac/) * -## Running locally +## Running locally from repo You need to use special techniques to run `ronn` locally, entirely from the local repo and dev environment, instead of pulling stuff in from the main local system, including system-level installed gems and `ronn` itself. @@ -74,17 +76,41 @@ It would be nice for plain `./bin/ronn` or `ronn` with `./bin` on the `$PATH` to ## Running tests -Doing `bundle exec rake test` will run all the tests. +There are a few different scenarios or envs that tests can be run under: + +* Repo code, dev Ruby, repo-driven gem deps +* Repo code, env-provided gem deps + * Where "env" means some external environment, not the dev Ruby you set up +* Installed code, env-provided gem deps + * Testing after-deployment code, like done by `brew install` or an RPM package + +The "dev env" section above mostly describes scenario 1. TODO: Update this document to reflect the additional dev & test scenarios. + +Running `rake test` will run all the unit tests. Depending on the scenario, you may need to decorate or enclose it in something. + +Do `RONN_QUIET_TEST=1 rake test` for shorter output that omits the possibly-long results-diff outputs. + +### Repo code, repo-driven gem deps + +Here, we use rbenv and bundler to manage gems, so the `rake` commands go inside bundler calls. + +Switch to your rbenv-managed development Ruby, and do `bundle install` per above to install the gem deps. Then do `bundle exec rake test` to run the tests against that dev Ruby. + +The `rake test` should be done against each of the supported Ruby major versions we're developing and testing against. TODO: Add a script that automates that. + +### Repo code, system deps: Fedora + +Fedora packages Ronn-NG in an RPM that uses gem dependencies from other `rubygem-*` RPMs, which are installed in to the system ruby, and (I think) available by default, without using Bundler. So if you install those gem RPMs and run against the system ruby, then you're testing how the Fedora-distributed Ronn-NG will end up running when shipped in that Fedora distro/release. The `devkit/install-fedora-deps.sh` script will do the installation. -Do `RONN_QUIET_TEST=1 bundle exec rake test` for shorter output that omits the possibly-long results-diff outputs. +On the other hand, installing the gem deps at the system level means that you're not validating the gem/bundler dependency definitions in the current repo code. And do not install the ronn-ng RPM itself, because then the system-installed Ronn-NG code will contaminate your testing of the repo code. -The `rake test` should be done against each of the supported Ruby versions we're developing and testing against. TODO: Add a script that automates that. +To test this way, install the gem RPMs, and then run `rake test` or `./bin/ronn` from the repo, without doing `bundler exec` or other wrapping. ## Git commits I like Git commit messages that have a "[blah]" prefix to indicate what area of the code they did something to. If you're going to do commits or PRs, please consider wording your commit messages that way. -In late 2023, I experimented wiht "blah:" instead of "[blah]" prefixes, but I think I like "[blah]" better, and am sticking with that now. +In late 2023, I experimented with "blah:" instead of "[blah]" prefixes, but I think I like "[blah]" better, and am sticking with that now. Prefixes I use as of 2024-01: