brewer 0.0.93 β 0.0.96
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Rakefile +0 -14
- data/bin/brewer +4 -1
- data/lib/brewer/adaptibrew.rb +4 -0
- data/lib/brewer/procedures.rb +4 -3
- data/lib/brewer/recipe.rb +14 -7
- data/lib/brewer/settings.rb +0 -0
- data/lib/brewer/slacker.rb +20 -10
- data/spec/adaptibrew_spec.rb +9 -0
- data/spec/recipe_spec.rb +19 -0
- metadata +1 -1
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 7927d9a39ff0ffd75b6d30ade81f12aabd6ef3d2
|
4
|
+
data.tar.gz: d256430f647cfb8e7bddde784fe0c2c45e82c088
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 2e9e2266694be8381150a0dc2e133d81cbbda157875bdcdded2fd667a49ee043d119ac77c78a95c7736feb55eadd067b7b0fd3d9bac7c847c4a9ab3bf12f9b71
|
7
|
+
data.tar.gz: 84363974da9c34024bb73a7af7af7b81823155c4ca80b484e5b789f689890445ed752b4cc040ecaa9ff1dfa64ed3fb4e14b5d9458bc215822630eaa182106625
|
data/Rakefile
CHANGED
@@ -44,17 +44,3 @@ end
|
|
44
44
|
task :clear_coverage do
|
45
45
|
rm_rf('coverage/')
|
46
46
|
end
|
47
|
-
|
48
|
-
# Adaptibrew tasks
|
49
|
-
# Clear, Clone, and Refresh
|
50
|
-
task :adaptibrew, [:method] do |t, method|
|
51
|
-
case method.to_a.first
|
52
|
-
when 'clear'
|
53
|
-
rm_rf 'adaptibrew/'
|
54
|
-
when 'clone'
|
55
|
-
Git.clone('https://github.com/adaptiman/adaptibrew.git', 'adaptibrew')
|
56
|
-
when 'refresh'
|
57
|
-
rm_rf 'adaptibrew/'
|
58
|
-
Git.clone('https://github.com/adaptiman/adaptibrew.git', 'adaptibrew')
|
59
|
-
end
|
60
|
-
end
|
data/bin/brewer
CHANGED
@@ -2,9 +2,12 @@
|
|
2
2
|
require_relative "../lib/brewer"
|
3
3
|
|
4
4
|
adaptibrew = Brewer::Adaptibrew.new
|
5
|
-
|
5
|
+
adaptibrew.refresh
|
6
|
+
|
7
|
+
slack = Brewer::Slacker.new
|
6
8
|
brewer = Brewer::Brewer.new
|
7
9
|
procedures = Brewer::Procedures.new
|
8
10
|
|
11
|
+
|
9
12
|
binding.pry(quiet: true)
|
10
13
|
# πΊπΊπΊ
|
data/lib/brewer/adaptibrew.rb
CHANGED
@@ -11,6 +11,10 @@ module Brewer
|
|
11
11
|
@disable_network_operations = network? ? false : true
|
12
12
|
@adaptibrew_url = 'https://github.com/llamicron/adaptibrew.git'
|
13
13
|
|
14
|
+
if !Dir.exists?(brewer_dir)
|
15
|
+
Dir.mkdir(brewer_dir)
|
16
|
+
end
|
17
|
+
|
14
18
|
if !Dir.exists?(adaptibrew_dir)
|
15
19
|
Dir.mkdir(adaptibrew_dir)
|
16
20
|
end
|
data/lib/brewer/procedures.rb
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
require_relative "../brewer"
|
2
|
-
|
2
|
+
# :nocov:
|
3
3
|
module Brewer
|
4
4
|
class Procedures
|
5
5
|
|
@@ -40,7 +40,7 @@ module Brewer
|
|
40
40
|
true
|
41
41
|
end
|
42
42
|
|
43
|
-
|
43
|
+
|
44
44
|
def heat_strike_water
|
45
45
|
puts Rainbow("About to heat strike water").green
|
46
46
|
|
@@ -94,7 +94,7 @@ module Brewer
|
|
94
94
|
puts Rainbow("Strike water heated. Maintaining temp.").green
|
95
95
|
true
|
96
96
|
end
|
97
|
-
|
97
|
+
|
98
98
|
|
99
99
|
def dough_in
|
100
100
|
@brewer.relay_config({
|
@@ -220,3 +220,4 @@ module Brewer
|
|
220
220
|
|
221
221
|
end
|
222
222
|
end
|
223
|
+
# :nocov:
|
data/lib/brewer/recipe.rb
CHANGED
@@ -31,19 +31,23 @@ module Brewer
|
|
31
31
|
return true
|
32
32
|
end
|
33
33
|
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
34
|
+
if !list_recipes.empty?
|
35
|
+
clear_screen
|
36
|
+
puts "Enter a recipe name to load an existing recipe, or nothing to start a new one."
|
37
|
+
puts list_as_table
|
38
|
+
print "> "
|
39
|
+
name = gets.chomp.strip
|
40
|
+
else
|
41
|
+
puts Rainbow("No available recipes").yellow
|
42
|
+
name = ""
|
43
|
+
end
|
39
44
|
|
40
45
|
unless name.empty?
|
41
46
|
load(name)
|
42
47
|
return true
|
43
48
|
end
|
44
49
|
|
45
|
-
|
46
|
-
puts Rainbow("Variables for the brew").green
|
50
|
+
puts Rainbow("Creating a new recipe").green
|
47
51
|
|
48
52
|
get_strike_temp
|
49
53
|
|
@@ -127,6 +131,9 @@ module Brewer
|
|
127
131
|
end
|
128
132
|
|
129
133
|
def list_as_table
|
134
|
+
if list_recipes.empty?
|
135
|
+
return "No Saved Recipes."
|
136
|
+
end
|
130
137
|
recipes_table_rows = list_recipes.each_slice(5).to_a
|
131
138
|
recipes_table = Terminal::Table.new :title => "All Recipes", :rows => recipes_table_rows
|
132
139
|
return recipes_table
|
data/lib/brewer/settings.rb
CHANGED
File without changes
|
data/lib/brewer/slacker.rb
CHANGED
@@ -1,29 +1,38 @@
|
|
1
1
|
require_relative "../brewer"
|
2
|
-
|
2
|
+
# :nocov:
|
3
3
|
module Brewer
|
4
4
|
# This class is responsible for slack communication
|
5
5
|
class Slacker
|
6
6
|
|
7
7
|
attr_accessor :slack, :brewer
|
8
8
|
|
9
|
-
def initialize
|
9
|
+
def initialize(webhook=false)
|
10
10
|
@settings = Settings.new
|
11
11
|
@brewer = Brewer.new
|
12
|
-
@slack = configure_slack
|
12
|
+
@slack = configure_slack(webhook)
|
13
13
|
end
|
14
14
|
|
15
15
|
# This will look for a webhook in settings.yml and ask you for one if it doesn't find one
|
16
|
-
def configure_slack
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
})
|
16
|
+
def configure_slack(webhook)
|
17
|
+
if webhook
|
18
|
+
return Slack::Notifier.new webhook
|
19
|
+
end
|
20
|
+
if !@settings.settings['webhook_url']
|
21
|
+
get_webhook_url
|
23
22
|
end
|
24
23
|
return Slack::Notifier.new @settings.settings['webhook_url']
|
25
24
|
end
|
26
25
|
|
26
|
+
def get_new_webhook
|
27
|
+
print "Slack Webhook URL: "
|
28
|
+
webhook_url = gets.chomp
|
29
|
+
@settings.add({
|
30
|
+
'webhook_url' => webhook_url
|
31
|
+
})
|
32
|
+
@settings.cache
|
33
|
+
webhook_url
|
34
|
+
end
|
35
|
+
|
27
36
|
# This sends a message in slack.
|
28
37
|
# If an array is passed in, it will send it as one message with
|
29
38
|
# new lines between each array item
|
@@ -56,3 +65,4 @@ module Brewer
|
|
56
65
|
|
57
66
|
end
|
58
67
|
end
|
68
|
+
# :nocov:
|
data/spec/adaptibrew_spec.rb
CHANGED
@@ -17,6 +17,15 @@ describe Brewer::Adaptibrew do
|
|
17
17
|
it "makes a new Adaptibrew object" do
|
18
18
|
expect(Adaptibrew.new).to be_an_instance_of Adaptibrew
|
19
19
|
end
|
20
|
+
|
21
|
+
context "when the adaptibrew and brewer directories dont exist" do
|
22
|
+
before { FileUtils.rm_rf(brewer_dir) }
|
23
|
+
it "creates them" do
|
24
|
+
a = Adaptibrew.new
|
25
|
+
expect(Dir.exists?(brewer_dir)).to be true
|
26
|
+
expect(Dir.exists?(adaptibrew_dir)).to be true
|
27
|
+
end
|
28
|
+
end
|
20
29
|
end
|
21
30
|
|
22
31
|
describe ".clear" do
|
data/spec/recipe_spec.rb
CHANGED
@@ -78,4 +78,23 @@ describe Recipe do
|
|
78
78
|
end
|
79
79
|
end
|
80
80
|
|
81
|
+
describe ".list_as_table" do
|
82
|
+
context "when there are no recipes" do
|
83
|
+
before { FileUtils.rm_rf(Dir.glob(recipe_dir("*"))) }
|
84
|
+
it "returns without a table" do
|
85
|
+
expect(@recipe.list_as_table).to eq("No Saved Recipes.")
|
86
|
+
end
|
87
|
+
end
|
88
|
+
|
89
|
+
context "when there are recipes" do
|
90
|
+
before {
|
91
|
+
@recipe.new_dummy
|
92
|
+
@recipe.store
|
93
|
+
}
|
94
|
+
it "returns a TerminalTable" do
|
95
|
+
expect(@recipe.list_as_table).to be_an_instance_of Terminal::Table
|
96
|
+
end
|
97
|
+
end
|
98
|
+
end
|
99
|
+
|
81
100
|
end
|