Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ on:
pull_request:

jobs:
unit_tests:
tests:
runs-on: ubuntu-latest
steps:
- name: Set up latest stable Go
Expand All @@ -27,4 +27,4 @@ jobs:
fetch-tags: 1
fetch-depth: 0
- name: Run Go unit tests
run: go test ./...
run: make test
130 changes: 96 additions & 34 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -3,26 +3,21 @@
# SPDX-License-Identifier: MIT

# Set path to commands
GO ?= $(shell command -v go 2>/dev/null)
GIT ?= $(shell command -v git 2>/dev/null)
GO ?= $(shell command -v go 2>/dev/null)
GOLANGCI_LINT ?= $(shell command -v golangci-lint 2>/dev/null)
GORELEASER ?= $(shell command -v goreleaser 2>/dev/null)
GIT ?= $(shell command -v git 2>/dev/null)
AWK ?= $(shell command -v awk 2>/dev/null)
REUSE ?= $(shell command -v reuse 2>/dev/null)
# Use HOSTCMD to not conflict with Make's $(HOSTNAME)
HOSTCMD ?= $(shell command -v hostname 2>/dev/null)
INSTALL ?= $(shell command -v install 2>/dev/null)
SCDOC ?= $(shell command -v scdoc 2>/dev/null)
SHELL ?= /bin/sh
HOSTCMD ?= $(shell command -v hostname 2>/dev/null)
INSTALL ?= $(shell command -v install 2>/dev/null)
SCDOC ?= $(shell command -v scdoc 2>/dev/null)
SHELL ?= /bin/sh

INSTALL_PROGRAM ?= $(INSTALL) -Dm755
INSTALL_DATA ?= $(INSTALL) -Dm644

IMPORT := github.com/OpenCHAMI/ochami/

prefix ?= /usr/local
exec_prefix ?= $(prefix)
bindir ?= $(exec_prefix)/bin
mandir ?= $(exec_prefix)/man
libexecdir ?= $(prefix)/usr/libexec/ochami
sharedir ?= $(prefix)/usr/share

# Check that commands are present
ifeq ($(GIT),)
$(error git command not found.)
Expand All @@ -41,6 +36,7 @@ endif
rwildcard = $(foreach d,$(wildcard $(1:=/*)),$(call rwildcard,$d,$2) $(filter $(subst *,%,$2),$d))

NAME ?= ochami
IMPORT := github.com/OpenCHAMI/$(NAME)/
VERSION ?= $(shell $(GIT) describe --tags --always --dirty --broken --abbrev=0)
TAG ?= $(shell $(GIT) describe --tags --always --abbrev=0)
BRANCH ?= $(shell $(GIT) branch --show-current)
Expand Down Expand Up @@ -70,52 +66,118 @@ MAN5BIN := $(filter %.5,$(MANBIN))

HELPERS := extras/scripts/ochami-discovery-old2new.py

prefix ?= /usr/local
exec_prefix ?= $(prefix)
bindir ?= $(exec_prefix)/bin
mandir ?= $(exec_prefix)/man
libexecdir ?= $(prefix)/usr/libexec/$(NAME)
sharedir ?= $(prefix)/usr/share

.PHONY: all
all: binaries
all: binaries ## Build everything

.PHONY: binaries
binaries: $(NAME)
binaries: $(NAME) ## Build binaries

.PHONY: help
help: ## Show this help
ifeq ($(AWK),)
$(error awk command not found.)
endif
@$(AWK) 'BEGIN {FS = ":.*##"; printf "\nUsage:\n make \033[36m[VAR=val]... <target>\033[0m\n\nTargets:\n"} \
/^[a-zA-Z0-9_\/.-]+:.*##/ { \
printf " \033[36m%-22s\033[0m %s\n", $$1, $$2 \
}' $(MAKEFILE_LIST)

.PHONY: goreleaser-build
goreleaser-build: ## Run `goreleaser build` (accepts GORELEASER_OPTS)
ifeq ($(GO),)
$(error go command not found.)
endif
ifeq ($(GORELEASER),)
$(error goreleaser command not found.)
endif
env \
GOVERSION=$(GOVER) \
BUILD_HOST=$(BUILDHOST) \
BUILD_USER=$(BUILDUSER) \
$(GORELEASER) build $(GORELEASER_OPTS)

.PHONY: goreleaser-release
goreleaser-release: ## Run `goreleaser release` (accepts GORELEASER_OPTS)
ifeq ($(GO),)
$(error go command not found.)
endif
ifeq ($(GORELEASER),)
$(error goreleaser command not found.)
endif
env \
GOVERSION=$(GOVER) \
BUILD_HOST=$(BUILDHOST) \
BUILD_USER=$(BUILDUSER) \
$(GORELEASER) release $(GORELEASER_OPTS)

.PHONY: goreleaser-clean
goreleaser-clean: ## Clean Goreleaser files (remove dist/)
$(RM) -rf dist/

.PHONY: check-reuse
check-reuse:
ifeq ($(REUSE),)
$(error reuse command not found)
endif
reuse lint

.PHONY: lint
lint:
ifeq ($(GOLANGCI_LINT),)
$(error golangci-lint command not found)
endif
$(GOLANGCI_LINT) run

.PHONY: test
test: unit-test ## Run all tests

.PHONY: unittest
unittest:
.PHONY: unit-test
unit-test: ## Run unit tests only
ifeq ($(GO),)
$(error go command not found.)
endif
$(GO) test -cover -v ./...

.PHONY: clean
clean:
clean: ## Clean Go build artifacts
ifeq ($(GO),)
$(error go command not found.)
endif
$(GO) clean -i -x

.PHONY: clean-man
clean-man:
clean-man: ## Clean generated manual pages
rm -f $(MANBIN)

.PHONY: clean-completions
clean-completions:
clean-completions: ## Clean generated shell completions
rm -rf completions/

completions: $(NAME)
completions: $(NAME) ## Generate shell completions
./scripts/completions.sh

.PHONY: distclean
distclean: clean clean-completions clean-man
distclean: clean clean-completions clean-man ## Clean everything (prepare for distribution)

.PHONY: install
install: install-prog install-helper install-completions install-man
install: install-prog install-helper install-completions install-man ## Install everything

.PHONY: install-prog
install-prog: $(NAME)
install-prog: $(NAME) ## Install program
ifeq ($(INSTALL),)
$(error install command not found.)
endif
$(INSTALL_PROGRAM) $(NAME) $(DESTDIR)$(bindir)/$(NAME)

.PHONY: install-helper
install-helper: $(HELPERS)
install-helper: $(HELPERS) ## Install helper scripts
ifeq ($(INSTALL),)
$(error install command not found.)
endif
Expand All @@ -124,7 +186,7 @@ endif
done

.PHONY: install-completions
install-completions: completions
install-completions: completions ## Install shell completions
ifeq ($(INSTALL),)
$(error install command not found.)
endif
Expand All @@ -133,7 +195,7 @@ endif
$(INSTALL_DATA) ./completions/ochami.zsh $(DESTDIR)$(sharedir)/zsh/site-functions/_ochami

.PHONY: install-man
install-man: $(MANBIN)
install-man: $(MANBIN) ## Install manual pages
ifeq ($(INSTALL),)
$(error install command not found.)
endif
Expand All @@ -143,7 +205,7 @@ endif
$(INSTALL_DATA) $(MAN5BIN) $(DESTDIR)$(mandir)/man5/

.PHONY: man
man: $(MANBIN)
man: $(MANBIN) ## Generate manual pages

man/%: man/%.sc
ifeq ($(SCDOC),)
Expand All @@ -152,20 +214,20 @@ endif
$(SCDOC) < $< > $@

.PHONY: uninstall
uninstall: uninstall-prog uninstall-completions uninstall-man
uninstall: uninstall-prog uninstall-completions uninstall-man ## Uninstall everything

.PHONY: uninstall-prog
uninstall-prog:
uninstall-prog: ## Uninstall program
rm -f $(DESTDIR)$(bindir)/$(NAME)

.PHONY: uninstall-completions
uninstall-completions:
uninstall-completions: ## Uninstall shell completions
rm -f $(DESTDIR)/usr/share/bash-completion/completions/ochami
rm -f $(DESTDIR)/usr/share/fish/vendor_completions.d/ochami.fish
rm -f $(DESTDIR)/usr/share/zsh/site-functions/_ochami

.PHONY: uninstall-man
uninstall-man:
uninstall-man: ## Uninstall manual pages
rm -f $(foreach man1page,$(subst man/,,$(MAN1BIN)),$(DESTDIR)$(mandir)/man1/$(man1page))
rm -f $(foreach man5page,$(subst man/,,$(MAN5BIN)),$(DESTDIR)$(mandir)/man5/$(man5page))

Expand Down
16 changes: 13 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -95,6 +95,7 @@ default-cluster: foobar
log:
format: rfc3339
level: warning
timeout: 30s

```

Expand All @@ -103,7 +104,7 @@ log:
Test access by contacting an API endpoint not requiring an access token:

```bash
$ ochami bss status
$ ochami bss service status
{"bss-status":"running"}

```
Expand Down Expand Up @@ -154,10 +155,19 @@ goreleaser build --clean --snapshot --single-target

Remove `--single-target` to build for all targets.

There is also a `goreleaser-build` make target that sets variables
automatically:

```bash
make GORELEASER_OPTS='--clean --snapshot --single-target' goreleaser-build
```

### Make

Make provides convenient and quick building for fast iteration and development.

Run `make help` to see available targets.

Linker flags are used to embed build metadata into the binary. Building can
simply be done via:

Expand All @@ -177,7 +187,7 @@ sudo make install
### Pulling

```bash
docker pull ghcr.io/synackd/ochami:latest
docker pull ghcr.io/openchami/ochami:latest
```

### Building
Expand All @@ -199,6 +209,6 @@ docker build . --tag ochami:dirty
### Running

```bash
docker run ghcr.io/synackd/ochami:latest ochami --ignore-config help
docker run ghcr.io/openchami/ochami:latest ochami --ignore-config help
```
The above incantation will print out the command line's help message.
Loading