From 9edd7cfa615cb83e63e4b2e32f00c7970c2270ac Mon Sep 17 00:00:00 2001 From: Michael Savin Date: Tue, 7 Dec 2021 22:18:59 +0300 Subject: [PATCH 1/3] Add some magic --- .github/FUNDING.yml | 4 +--- .github/RELEASE-TEMPLATE.md | 3 --- .github/workflows/build.yml | 4 ++-- README.md | 1 + cmd/root.go | 7 +++++-- cmd/version.go | 4 +++- cmd/watch.go | 33 ++++++++++++++++++++++++++------- main.go | 8 ++++++++ pkg/executor/executor.go | 2 +- pkg/waiter/waiter.go | 12 +++++++++--- 10 files changed, 56 insertions(+), 22 deletions(-) delete mode 100644 .github/RELEASE-TEMPLATE.md diff --git a/.github/FUNDING.yml b/.github/FUNDING.yml index e381c96..b73fc2c 100644 --- a/.github/FUNDING.yml +++ b/.github/FUNDING.yml @@ -1,4 +1,2 @@ -github: - - jtprogru - - t0pep0 +github: [ "jtprogru", "t0pep0" ] diff --git a/.github/RELEASE-TEMPLATE.md b/.github/RELEASE-TEMPLATE.md deleted file mode 100644 index 99c6d3c..0000000 --- a/.github/RELEASE-TEMPLATE.md +++ /dev/null @@ -1,3 +0,0 @@ -# Announcements - -* First announcement diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index e39e907..c2f1859 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -18,7 +18,7 @@ jobs: - uses: actions/checkout@v2.4.0 - uses: actions/setup-go@v2 with: - go-version: '1.16.4' + go-version: '1.17.3' - name: golangci-lint uses: golangci/golangci-lint-action@v2.5.2 with: @@ -63,6 +63,6 @@ jobs: with: body_path: ".github/RELEASE-TEMPLATE.md" draft: true - files: ${{env.BINARY_NAME}} + files: ${{ env.BINARY_NAME }} env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/README.md b/README.md index 749d5f3..c596f81 100644 --- a/README.md +++ b/README.md @@ -6,6 +6,7 @@ [![GitHub stars](https://img.shields.io/github/stars/jtprogru/go-monkill.svg)](https://github.com/jtprogru/go-monkill/stargazers) [![GitHub issues](https://img.shields.io/github/issues-raw/jtprogru/go-monkill)](https://github.com/jtprogru/go-monkill/issues) [![GitHub release (latest by date)](https://img.shields.io/github/v/release/jtprogru/go-monkill)](https://github.com/jtprogru/go-monkill/releases/latest) +[![Go report](https://goreportcard.com/badge/github.com/jtprogru/go-monkill)](https://goreportcard.com/report/github.com/jtprogru/go-monkill) ![GitHub](https://img.shields.io/github/license/jtprogru/go-monkill) ![Linux](https://img.shields.io/badge/-Linux-grey?logo=linux) [![Donate](https://img.shields.io/badge/-Donate-yellow?logo=paypal)](https://paypal.me/jtprogru) diff --git a/cmd/root.go b/cmd/root.go index 1e34110..90c9a36 100644 --- a/cmd/root.go +++ b/cmd/root.go @@ -1,12 +1,15 @@ +// Package cmd contains all commands + package cmd import ( "github.com/spf13/cobra" ) -const Version string = "v0.1.1" +const Version string = "v1.0.0" -// rootCmd represents the base command when called without any subcommands +// rootCmd – default root command +// rootCmd show help message var rootCmd = &cobra.Command{ Use: "monkill", Short: "Monkill for watching a process will finish or be killed", diff --git a/cmd/version.go b/cmd/version.go index b053900..a91e55e 100644 --- a/cmd/version.go +++ b/cmd/version.go @@ -1,3 +1,5 @@ +// Package cmd contains all commands + package cmd import ( @@ -6,7 +8,7 @@ import ( "github.com/spf13/cobra" ) -// versionCmd represents the version command +// versionCmd – show current version of this package var versionCmd = &cobra.Command{ Use: "version", Short: "Print the version number of monkill", diff --git a/cmd/watch.go b/cmd/watch.go index 7773455..7c902d4 100644 --- a/cmd/watch.go +++ b/cmd/watch.go @@ -1,3 +1,5 @@ +// Package cmd contains all commands + package cmd import ( @@ -9,7 +11,8 @@ import ( "github.com/spf13/cobra" ) -// watchCmd represents the watch command +// watchCmd – run watch func +// var watchCmd = &cobra.Command{ Use: "watch", Short: "A brief description of your command", @@ -17,18 +20,27 @@ var watchCmd = &cobra.Command{ For example: -go-monkill watch --pid=12345 --command="ping jtprog.ru -c 4"" +go-monkill watch --pid 12345 --command "ping jtprog.ru -c 4" `, RunE: func(cmd *cobra.Command, args []string) error { l := zerolog.New(os.Stderr) - return watcher(WatcherConfig.pid, WatcherConfig.command, waiter.Waiter{}, executor.Executor{}, l) + return watcher(WatcherConfig.pid, WatcherConfig.command, WatcherConfig.timeout, waiter.Waiter{}, executor.Executor{}, l) }, } +// Verbose flag +//var Verbose bool +// defaultPid +var defaultPid int = -1 + +// defaultTimeOut +var defaultTimeOut int64 = 250 + // WatcherConfig provides config for watcher var WatcherConfig struct { pid int // Specified PID for process command string // Specified command for running + timeout int64 // Specified timeout for sleep } // Add command watchCmd to rootCmd @@ -37,13 +49,16 @@ var WatcherConfig struct { // &WatcherConfig command as command for running - defined in flag --command func init() { rootCmd.AddCommand(watchCmd) - watchCmd.PersistentFlags().IntVar(&WatcherConfig.pid, "pid", -1, "PID for watching") + // TODO: Implement verbose log output by flag + //rootCmd.InheritedFlags().BoolVar(&Verbose, "verbose", false, "Enable debug logging") + watchCmd.PersistentFlags().IntVar(&WatcherConfig.pid, "pid", defaultPid, "PID for watching") watchCmd.PersistentFlags().StringVar(&WatcherConfig.command, "command", "ping jtprog.ru -c 2", "Command for running") + watchCmd.PersistentFlags().Int64Var(&WatcherConfig.timeout, "timeout", defaultTimeOut, "Set timeout for check status of process") } // Waiter interface type Waiter interface { - Wait(pid int) (<-chan struct{}, error) + Wait(pid int, timeout int64) (<-chan struct{}, error) } // Executor interface @@ -51,9 +66,13 @@ type Executor interface { Exec(command string) error } -func watcher(pid int, command string, w Waiter, e Executor, l zerolog.Logger) error { +// watcher – run Waiter.Wait +// &WatcherConfig pid as PID for monitoring – defined in flag --pid +// &WatcherConfig command as command for running - defined in flag --command +// &WatcherConfig timeout as timeout for watch - defined in flag --timeout +func watcher(pid int, command string, timeout int64, w Waiter, e Executor, l zerolog.Logger) error { l.Info().Int("pid", pid).Str("command", command).Msg("Arguments readed") - ch, err := w.Wait(pid) + ch, err := w.Wait(pid, timeout) if err != nil { l.Error().Err(err).Msg("Break execution. Error on watch process") return err diff --git a/main.go b/main.go index 5824225..2c3d2e4 100644 --- a/main.go +++ b/main.go @@ -1,3 +1,11 @@ +// Package go-monkill +// A very simple utility that allows you to run the desired command or script +// as soon as a certain process with a known PID completes correctly or with an error. +// +// For example: +// +// go-monkill watch --pid 12345 --command "ping jtprog.ru -c 4" + package main import "github.com/jtprogru/go-monkill/cmd" diff --git a/pkg/executor/executor.go b/pkg/executor/executor.go index ec7b614..d1e32bf 100644 --- a/pkg/executor/executor.go +++ b/pkg/executor/executor.go @@ -10,7 +10,7 @@ import ( // Executor struct type Executor struct{} -// Exec for running Executor with command +// Exec - running Executor with command (i.e.: "ping jtprog.ru -c 4" ) func (e Executor) Exec(command string) error { cmds := strings.Split(command, " ") if len(cmds) == 0 { diff --git a/pkg/waiter/waiter.go b/pkg/waiter/waiter.go index b4e0b8b..fd290af 100644 --- a/pkg/waiter/waiter.go +++ b/pkg/waiter/waiter.go @@ -1,12 +1,17 @@ package waiter -import "github.com/mitchellh/go-ps" +import ( + "github.com/mitchellh/go-ps" + "time" +) // Waiter struct type Waiter struct{} -// Wait monitor process with defined PID -func (w Waiter) Wait(pid int) (<-chan struct{}, error) { +// Wait find process with defined PID and wait for process will finish or be killed +// Checking the liveliness of the process occurs with a timeout delay +// The timeout is set in milliseconds +func (w Waiter) Wait(pid int, timeout int64) (<-chan struct{}, error) { _, err := ps.FindProcess(pid) if err != nil { return nil, err @@ -17,6 +22,7 @@ func (w Waiter) Wait(pid int) (<-chan struct{}, error) { if pc, _ := ps.FindProcess(pid); pc == nil { out <- struct{}{} } + time.Sleep(time.Duration(timeout) / time.Second) } }() return out, nil From 41f12698f4674867912346577b9e6841c8ecd1f4 Mon Sep 17 00:00:00 2001 From: Michael Savin Date: Wed, 8 Dec 2021 13:19:39 +0300 Subject: [PATCH 2/3] Update workflows --- .github/RELEASE-TEMPLATE.md | 4 ++++ .github/workflows/build.yml | 27 ++++++-------------------- .github/workflows/golangci-lint.yml | 30 +++++++++++++++++++++++++++++ README.md | 6 ++++-- 4 files changed, 44 insertions(+), 23 deletions(-) create mode 100644 .github/RELEASE-TEMPLATE.md create mode 100644 .github/workflows/golangci-lint.yml diff --git a/.github/RELEASE-TEMPLATE.md b/.github/RELEASE-TEMPLATE.md new file mode 100644 index 0000000..cf16c56 --- /dev/null +++ b/.github/RELEASE-TEMPLATE.md @@ -0,0 +1,4 @@ +# Release name + +- First feature +- Second feature diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index c2f1859..1250902 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -1,6 +1,9 @@ on: - push: - branches: [main] + workflow_run: + workflows: [ "GolangCI-lint" ] + branches: [ main ] + types: + - completed pull_request: branches: [main] @@ -11,38 +14,20 @@ defaults: shell: bash jobs: - lint: - name: Lint files - runs-on: 'ubuntu-latest' - steps: - - uses: actions/checkout@v2.4.0 - - uses: actions/setup-go@v2 - with: - go-version: '1.17.3' - - name: golangci-lint - uses: golangci/golangci-lint-action@v2.5.2 - with: - version: latest - build: name: Build binary runs-on: 'ubuntu-latest' - needs: lint strategy: matrix: goosarch: - 'darwin/amd64' - - 'darwin/arm64' - - 'linux/386' - 'linux/amd64' - - 'linux/arm' - - 'linux/arm64' steps: - name: Checkout code uses: actions/checkout@v2.4.0 - uses: actions/setup-go@v2 with: - go-version: '1.17.3' + go-version: '1.17' - name: Get OS and arch info run: | diff --git a/.github/workflows/golangci-lint.yml b/.github/workflows/golangci-lint.yml new file mode 100644 index 0000000..659db33 --- /dev/null +++ b/.github/workflows/golangci-lint.yml @@ -0,0 +1,30 @@ +on: + push: + paths: + - "go.sum" + - "go.mod" + - "**.go" + - ".github/workflows/golangci-lint.yml" + - ".golangci.yml" + pull_request: + paths: + - "go.sum" + - "go.mod" + - "**.go" + - ".github/workflows/golangci-lint.yml" + - ".golangci.yml" + +name: GolangCI-lint + +jobs: + golangci: + name: lint + runs-on: ubuntu-latest + steps: + - name: Checkout repository + uses: actions/checkout@v2 + + - name: Lint + uses: golangci/golangci-lint-action@v2 + with: + version: v1.42.0 diff --git a/README.md b/README.md index c596f81..0b1b392 100644 --- a/README.md +++ b/README.md @@ -1,15 +1,17 @@ # go-monkill [![Go Reference](https://pkg.go.dev/badge/github.com/jtprogru/go-monkill.svg)](https://pkg.go.dev/github.com/jtprogru/go-monkill) +[![GolangCI-lint](https://github.com/jtprogru/go-monkill/actions/workflows/golangci-lint.yml/badge.svg)](https://github.com/jtprogru/go-monkill/actions/workflows/golangci-lint.yml) [![build](https://github.com/jtprogru/go-monkill/actions/workflows/build.yml/badge.svg)](https://github.com/jtprogru/go-monkill/actions/workflows/build.yml) [![publish](https://github.com/jtprogru/go-monkill/actions/workflows/publish.yml/badge.svg)](https://github.com/jtprogru/go-monkill/actions/workflows/publish.yml) [![GitHub stars](https://img.shields.io/github/stars/jtprogru/go-monkill.svg)](https://github.com/jtprogru/go-monkill/stargazers) [![GitHub issues](https://img.shields.io/github/issues-raw/jtprogru/go-monkill)](https://github.com/jtprogru/go-monkill/issues) [![GitHub release (latest by date)](https://img.shields.io/github/v/release/jtprogru/go-monkill)](https://github.com/jtprogru/go-monkill/releases/latest) [![Go report](https://goreportcard.com/badge/github.com/jtprogru/go-monkill)](https://goreportcard.com/report/github.com/jtprogru/go-monkill) -![GitHub](https://img.shields.io/github/license/jtprogru/go-monkill) -![Linux](https://img.shields.io/badge/-Linux-grey?logo=linux) +[![GitHub](https://img.shields.io/github/license/jtprogru/go-monkill)](LICENSE) +[![Linux](https://img.shields.io/badge/-Linux-grey?logo=linux)](https://en.wikipedia.org/wiki/Linux) [![Donate](https://img.shields.io/badge/-Donate-yellow?logo=paypal)](https://paypal.me/jtprogru) +[![LoC](https://tokei.rs/b1/github/jtprogru/go-monkill)](https://github.com/jtprogru/go-monkill) A very simple utility that allows you to run the desired command or script as soon as a certain process with a known PID completes correctly or with an error. From 05a72809ad88254cec70209c45f7549b0ae6bde3 Mon Sep 17 00:00:00 2001 From: Michael Savin Date: Wed, 8 Dec 2021 13:20:15 +0300 Subject: [PATCH 3/3] Add default timeout --- cmd/root.go | 3 ++- cmd/watch.go | 15 ++++++++++----- pkg/executor/executor.go | 1 + pkg/waiter/waiter.go | 6 +++--- 4 files changed, 16 insertions(+), 9 deletions(-) diff --git a/cmd/root.go b/cmd/root.go index 90c9a36..f930418 100644 --- a/cmd/root.go +++ b/cmd/root.go @@ -6,7 +6,8 @@ import ( "github.com/spf13/cobra" ) -const Version string = "v1.0.0" +// Version of release +const Version string = "v0.2.0" // rootCmd – default root command // rootCmd show help message diff --git a/cmd/watch.go b/cmd/watch.go index 7c902d4..61838bb 100644 --- a/cmd/watch.go +++ b/cmd/watch.go @@ -24,16 +24,18 @@ go-monkill watch --pid 12345 --command "ping jtprog.ru -c 4" `, RunE: func(cmd *cobra.Command, args []string) error { l := zerolog.New(os.Stderr) + l.Level(zerolog.TraceLevel) return watcher(WatcherConfig.pid, WatcherConfig.command, WatcherConfig.timeout, waiter.Waiter{}, executor.Executor{}, l) }, } // Verbose flag //var Verbose bool -// defaultPid + +// defaultPid is -1 for var defaultPid int = -1 -// defaultTimeOut +// defaultTimeOut is 250 milliseconds var defaultTimeOut int64 = 250 // WatcherConfig provides config for watcher @@ -47,16 +49,19 @@ var WatcherConfig struct { // // &WatcherConfig pid as PID for monitoring – defined in flag --pid // &WatcherConfig command as command for running - defined in flag --command +// &WatcherConfig timeout as timeout for check process - defined in flag --timeout func init() { rootCmd.AddCommand(watchCmd) - // TODO: Implement verbose log output by flag - //rootCmd.InheritedFlags().BoolVar(&Verbose, "verbose", false, "Enable debug logging") + // TODO: Implement verbose log output by flag --verbose + // rootCmd.InheritedFlags().BoolVar(&Verbose, "verbose", false, "Enable debug logging") + // TODO: Implement output to logfile by flag --logfile + // rootCmd.InheritedFlags().StringVar(&WatcherConfig.logfile, "logfile", "/tmp/go-monkill.log", "Enable debug logging") watchCmd.PersistentFlags().IntVar(&WatcherConfig.pid, "pid", defaultPid, "PID for watching") watchCmd.PersistentFlags().StringVar(&WatcherConfig.command, "command", "ping jtprog.ru -c 2", "Command for running") watchCmd.PersistentFlags().Int64Var(&WatcherConfig.timeout, "timeout", defaultTimeOut, "Set timeout for check status of process") } -// Waiter interface +// Waiter interface for monitor process PID every timeout milliseconds type Waiter interface { Wait(pid int, timeout int64) (<-chan struct{}, error) } diff --git a/pkg/executor/executor.go b/pkg/executor/executor.go index d1e32bf..a52d164 100644 --- a/pkg/executor/executor.go +++ b/pkg/executor/executor.go @@ -11,6 +11,7 @@ import ( type Executor struct{} // Exec - running Executor with command (i.e.: "ping jtprog.ru -c 4" ) +// TODO: Implement verbose logging for output func (e Executor) Exec(command string) error { cmds := strings.Split(command, " ") if len(cmds) == 0 { diff --git a/pkg/waiter/waiter.go b/pkg/waiter/waiter.go index fd290af..fb9d917 100644 --- a/pkg/waiter/waiter.go +++ b/pkg/waiter/waiter.go @@ -8,9 +8,9 @@ import ( // Waiter struct type Waiter struct{} -// Wait find process with defined PID and wait for process will finish or be killed -// Checking the liveliness of the process occurs with a timeout delay -// The timeout is set in milliseconds +// Wait find process with defined PID and wait for process will finish or be killed. +// Checking the liveliness of the process occurs with a timeout delay. +// The timeout is set in milliseconds. func (w Waiter) Wait(pid int, timeout int64) (<-chan struct{}, error) { _, err := ps.FindProcess(pid) if err != nil {