summaryrefslogtreecommitdiff
path: root/spec/models/warm_up_spec.rb
blob: d0e059768b2986d0dc27f8f5e92f497fdd0c1ebd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
require "rails_helper"

describe WarmUp do
  describe ".new" do
    describe "squat" do
      let(:squat) { build(:exercise, name: "Squat") }

      (45..60).step(5).each do |target_weight|
        it "has zero warm up sets" do
          expect(WarmUp.new(squat, target_weight).sets).to be_empty
        end
      end

      (65..400).step(5).each do |target_weight|
        it "calculates the warm up sets at #{target_weight} lbs" do
          sets = WarmUp.new(squat, target_weight).sets
          expect(sets).to be_present
          if target_weight >= 350
            expect(sets.length).to eql(9)
          elsif target_weight > 300
            expect(sets.length).to eql(8)
          elsif target_weight > 265
            expect(sets.length).to eql(7)
          elsif target_weight > 220
            expect(sets.length).to eql(6)
          elsif target_weight > 180
            expect(sets.length).to eql(5)
          elsif target_weight > 130
            expect(sets.length).to eql(4)
          elsif target_weight > 90
            expect(sets.length).to eql(3)
          elsif target_weight > 60
            expect(sets.length).to eql(2)
          end
        end
      end
    end

    describe "barbell row" do
      let(:barbell_row) { build(:exercise, name: "Barbell Row") }

      (45..100).step(5).each do |target_weight|
        it "has zero warm up sets" do
          expect(WarmUp.new(barbell_row, target_weight).sets).to be_empty
        end
      end

      (105..400).step(5).each do |target_weight|
        it "calculates the warm up sets for #{target_weight} lbs" do
          sets = WarmUp.new(barbell_row, target_weight).sets
          expect(sets).to be_present
          if target_weight >= 350
            expect(sets.length).to eql(6)
          elsif target_weight > 300
            expect(sets.length).to eql(5)
          elsif target_weight > 265
            expect(sets.length).to eql(4)
          elsif target_weight > 220
            expect(sets.length).to eql(3)
          elsif target_weight > 180
            expect(sets.length).to eql(2)
          elsif target_weight > 100
            expect(sets.length).to eql(1)
          end
        end
      end
    end

    describe "deadlift" do
      let(:deadlift) { build(:exercise, name: "Deadlift") }

      (45..150).step(5).each do |target_weight|
        it "has zero warm up sets at #{target_weight} lbs" do
          expect(WarmUp.new(deadlift, target_weight).sets).to be_empty
        end
      end

      (155..400).step(5).each do |target_weight|
        it "calculates the warm up sets for #{target_weight} lbs" do
          sets = WarmUp.new(deadlift, target_weight).sets
          expect(sets).to be_present
          if target_weight >= 350
            expect(sets.length).to eql(6)
          elsif target_weight > 300
            expect(sets.length).to eql(5)
          elsif target_weight > 265
            expect(sets.length).to eql(4)
          elsif target_weight > 220
            expect(sets.length).to eql(3)
          elsif target_weight > 170
            expect(sets.length).to eql(2)
          elsif target_weight > 100
            expect(sets.length).to eql(1)
          else
            puts [target_weight, sets.map(&:target_weight)].inspect
          end
        end
      end
    end
  end
end