From d4ccd632f468a06a0ac2337cc2d7656f119cc255 Mon Sep 17 00:00:00 2001 From: Dana Sherson Date: Sun, 3 Dec 2023 12:32:18 +1300 Subject: [PATCH] WIP Tidy --- .gitmodules | 9 -- asdfrc | 1 - bin/git_remote_main_branch | 2 +- bin/rc | 2 +- foo.txt | 1 - spec/git_rubocop_spec.rb | 211 +++++++++++++++++++------------------ 6 files changed, 111 insertions(+), 115 deletions(-) delete mode 100644 asdfrc delete mode 100644 foo.txt diff --git a/.gitmodules b/.gitmodules index 8e48a33..32fd8c9 100644 --- a/.gitmodules +++ b/.gitmodules @@ -1,12 +1,3 @@ -[submodule "test/test_helper/bats-support"] - path = test/test_helper/bats-support - url = https://github.com/bats-core/bats-support.git -[submodule "test/test_helper/bats-assert"] - path = test/test_helper/bats-assert - url = https://github.com/bats-core/bats-assert.git -[submodule "test/test_helper/bats-file"] - path = test/test_helper/bats-file - url = https://github.com/bats-core/bats-file.git [submodule "github-cctray"] path = github-cctray url = git@github.com:robotdana/github-cctray.git diff --git a/asdfrc b/asdfrc deleted file mode 100644 index e600bd0..0000000 --- a/asdfrc +++ /dev/null @@ -1 +0,0 @@ -legacy_version_file = yes diff --git a/bin/git_remote_main_branch b/bin/git_remote_main_branch index dcf0e69..28152b6 100644 --- a/bin/git_remote_main_branch +++ b/bin/git_remote_main_branch @@ -1,4 +1,4 @@ -#!/usr/bin/env +#!/usr/bin/env bash remotes=( $(git branch -vv -r | grep -E '^\s+[^/]+/HEAD' | cut -d'>' -f2) ) remote_heads=() diff --git a/bin/rc b/bin/rc index ec3f6b3..1e31c1b 100755 --- a/bin/rc +++ b/bin/rc @@ -1,3 +1,3 @@ -#!/usr/bin/env +#!/usr/bin/env bash rails console diff --git a/foo.txt b/foo.txt deleted file mode 100644 index 292b669..0000000 --- a/foo.txt +++ /dev/null @@ -1 +0,0 @@ -23456789Ž12345678 diff --git a/spec/git_rubocop_spec.rb b/spec/git_rubocop_spec.rb index 5cf115f..aa9f33c 100644 --- a/spec/git_rubocop_spec.rb +++ b/spec/git_rubocop_spec.rb @@ -1,3 +1,5 @@ +# frozen_string_literal: true + RSpec.describe 'git rubocop hooks' do before do copy_file('.ruby-version') @@ -12,7 +14,7 @@ run('bundle install') run('bundle lock --add-platform universal-darwin-20') run('bundle lock --add-platform x86_64-darwin-18') - git("init") + git('init') git_add('.') git_commit('--no-verify -m "Initial commit"') end @@ -59,10 +61,11 @@ def foo() file('foo.rb').write(good_rb) file('bar.rb').write(good_rb) git_add('.') - run "gc Pass rubocop" + run 'gc Pass rubocop' expect_clean_git_status expect_empty_stash - expect(git_log).to have_output(["Pass rubocop", "Initial commit"], split: true) + expect(git_log) + .to have_output(['Pass rubocop', 'Initial commit'], split: true) expect(file('foo.rb')).to exist expect(file('bar.rb')).to exist end @@ -95,14 +98,16 @@ def foo() end # TODO: make this less manual - it "partial add pass rubocop hook" do + it 'partial add pass rubocop hook' do file('foo.rb').write(good_rb) file('bar.rb').write(bad_rb) git_add('foo.rb') run('yes q | gc Pass rubocop', expect_exit: be_nonzero) # it fails due to the rebase not attempting, but does make the commit: - expect(git_log).to have_output(['Pass rubocop', 'Initial commit'], split: true) - expect(run('git show --pretty=format: --name-only')).to have_output("foo.rb\n") + expect(git_log) + .to have_output(['Pass rubocop', 'Initial commit'], split: true) + expect(run('git show --pretty=format: --name-only')) + .to have_output("foo.rb\n") run('git_rebasing', expect_exit: be_nonzero) expect(run('git_untracked')).to have_output("bar.rb\n") @@ -117,14 +122,18 @@ def foo() end # TODO: make this less manual - it "partial add fail rubocop hook" do + it 'partial add fail rubocop hook' do file('foo.rb').write(good_rb) file('bar.rb').write(bad_rb) git_add('bar.rb') run('yes q | gc Pass rubocop', expect_exit: be_nonzero) # it fails due to the rebase not attempting, but does make the commit: - expect(git_log).to have_output(['Pass rubocop', 'Initial commit'], split: true) - expect(run('git show --pretty=format: --name-only')).to have_output("bar.rb\n") + expect(git_log) + .to have_output( + ['Pass rubocop', 'Initial commit'], split: true + ) + expect(run('git show --pretty=format: --name-only')) + .to have_output("bar.rb\n") run('git_rebasing', expect_exit: be_nonzero) expect(run('git_untracked')).to have_output("foo.rb\n") @@ -134,8 +143,6 @@ def foo() run('git_autolint_head', expect_exit: be_nonzero) run('git_rebasing') file('bar.rb').write(good_rb) - require 'pry' - binding.pry run('yes | grc') run('git_rebasing', expect_exit: be_nonzero) @@ -144,94 +151,94 @@ def foo() end end - # @test "partial add autocorrect rubocop hook" { - # auto_bad_rb > bar.rb - # good_rb > foo.rb - # git add bar.rb - # ( yes q | RBENV_VERSION=3.2.2 rbenv exec gc "Auto rubocop" ) || true - # # this doesn't run rubocop because there are untracked files - # refute git_rebasing - # run git_untracked - # assert_output "foo.rb" - - # # manually lint - # git_stash_only_untracked - # yes y | RBENV_VERSION=3.2.2 rbenv exec git_autolint_head - # refute git_rebasing - - # git stash pop - # run git_untracked - # assert_output "foo.rb" - # } - - # @test "patch add pass rubocop hook" { - # good_rb > foo.rb - # git add foo.rb - # bad_rb >> foo.rb - # run git diff --cached --name-only - # assert_output "foo.rb" - # run git diff --name-only - # assert_output "foo.rb" - # yes n | RBENV_VERSION=3.2.2 rbenv exec gc "Pass rubocop" - # refute git_rebasing - # assert_equal "$(cat foo.rb)" "$(good_rb) - # $(bad_rb)" - # } - - # @test "patch add fail rubocop hook" { - # bad_rb > foo.rb - # git add foo.rb - # good_rb >> foo.rb - # run git diff --cached --name-only - # assert_output "foo.rb" - # run git diff --name-only - # assert_output "foo.rb" - # ( yes n | RBENV_VERSION=3.2.2 rbenv exec gc "Fail rubocop" ) || true - # assert git_rebasing - # good_rb > foo.rb - # yes | RBENV_VERSION=3.2.2 rbenv exec grc - # refute git_rebasing - # assert_equal "$(cat foo.rb)" "$(good_rb) - # $(good_rb)" - # } - - # @test "patch add autocorrect rubocop hook" { - # auto_bad_rb > foo.rb - # git add foo.rb - # echo "# comment" >> foo.rb - # run git diff --cached --name-only - # assert_output "foo.rb" - # run git diff --name-only - # assert_output "foo.rb" - # yes y | RBENV_VERSION=3.2.2 rbenv exec gc "Auto rubocop" - # refute git_rebasing - # assert_equal "$(cat foo.rb)" "$(good_rb) - # # comment" - # } - - # @test "patch add conflict fail rubocop hook" { - # bad_rb > foo.rb - # git add foo.rb - # good_rb > foo.rb - # echo "CONFLICT = false" >> foo.rb - # ( yes q | RBENV_VERSION=3.2.2 rbenv exec gc "Fail rubocop" ) || true - # assert git_rebasing - # good_rb > foo.rb - # echo "CONFLICTED = true" >> foo.rb - # yes | RBENV_VERSION=3.2.2 rbenv exec grc - # refute git_rebasing - - # run git log --format="%s" - # assert_output "Fail rubocop - # Initial commit" - # # assert_git_stash_empty - # assert_equal "$(cat foo.rb)" "$(good_rb) - # <<<<<<< Updated upstream - # CONFLICTED = true - # ||||||| Stash base - # ======= - # CONFLICT = false - # >>>>>>> Stashed changes" - # } - - # end +# @test "partial add autocorrect rubocop hook" { +# auto_bad_rb > bar.rb +# good_rb > foo.rb +# git add bar.rb +# ( yes q | RBENV_VERSION=3.2.2 rbenv exec gc "Auto rubocop" ) || true +# # this doesn't run rubocop because there are untracked files +# refute git_rebasing +# run git_untracked +# assert_output "foo.rb" + +# # manually lint +# git_stash_only_untracked +# yes y | RBENV_VERSION=3.2.2 rbenv exec git_autolint_head +# refute git_rebasing + +# git stash pop +# run git_untracked +# assert_output "foo.rb" +# } + +# @test "patch add pass rubocop hook" { +# good_rb > foo.rb +# git add foo.rb +# bad_rb >> foo.rb +# run git diff --cached --name-only +# assert_output "foo.rb" +# run git diff --name-only +# assert_output "foo.rb" +# yes n | RBENV_VERSION=3.2.2 rbenv exec gc "Pass rubocop" +# refute git_rebasing +# assert_equal "$(cat foo.rb)" "$(good_rb) +# $(bad_rb)" +# } + +# @test "patch add fail rubocop hook" { +# bad_rb > foo.rb +# git add foo.rb +# good_rb >> foo.rb +# run git diff --cached --name-only +# assert_output "foo.rb" +# run git diff --name-only +# assert_output "foo.rb" +# ( yes n | RBENV_VERSION=3.2.2 rbenv exec gc "Fail rubocop" ) || true +# assert git_rebasing +# good_rb > foo.rb +# yes | RBENV_VERSION=3.2.2 rbenv exec grc +# refute git_rebasing +# assert_equal "$(cat foo.rb)" "$(good_rb) +# $(good_rb)" +# } + +# @test "patch add autocorrect rubocop hook" { +# auto_bad_rb > foo.rb +# git add foo.rb +# echo "# comment" >> foo.rb +# run git diff --cached --name-only +# assert_output "foo.rb" +# run git diff --name-only +# assert_output "foo.rb" +# yes y | RBENV_VERSION=3.2.2 rbenv exec gc "Auto rubocop" +# refute git_rebasing +# assert_equal "$(cat foo.rb)" "$(good_rb) +# # comment" +# } + +# @test "patch add conflict fail rubocop hook" { +# bad_rb > foo.rb +# git add foo.rb +# good_rb > foo.rb +# echo "CONFLICT = false" >> foo.rb +# ( yes q | RBENV_VERSION=3.2.2 rbenv exec gc "Fail rubocop" ) || true +# assert git_rebasing +# good_rb > foo.rb +# echo "CONFLICTED = true" >> foo.rb +# yes | RBENV_VERSION=3.2.2 rbenv exec grc +# refute git_rebasing + +# run git log --format="%s" +# assert_output "Fail rubocop +# Initial commit" +# # assert_git_stash_empty +# assert_equal "$(cat foo.rb)" "$(good_rb) +# <<<<<<< Updated upstream +# CONFLICTED = true +# ||||||| Stash base +# ======= +# CONFLICT = false +# >>>>>>> Stashed changes" +# } + +# end