qalam_merit 4.0.4 → 4.5.03

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 6d18cb74d9ddf61a7a7d053c66cde90d8595a2b1a4aa707bfe7ab463e8d083e4
4
- data.tar.gz: 39f3ccf60a27aebbfed60abee1647143ca4b8cb63aab4b92942d1040e4558458
3
+ metadata.gz: 386d3c62bf3b26c03ad135cb78787e94dcba50aa9ff8e00901fff50f1970816a
4
+ data.tar.gz: 16d3cf72df7b2a8418577409d475ed76feeb01fb262f2652c83072ddda0c05e0
5
5
  SHA512:
6
- metadata.gz: 27abe76d15dacfe849056f2fa47a435a4699f8d19bebb990866ec2f7f8f2357f136f130f573ce905ca52f9c9412fce42a039b877dc7ba86253f9f7d846d0f7b8
7
- data.tar.gz: 6eaa19dbcb7d43c1e182bc18444420f6bc8bfdce6430a28a85453704e6c8bee391ac34ad3f5e257906868fc9a1565b9125689602eb283ee78f7fd27e81d11a8d
6
+ metadata.gz: aab0e7d069c2e76f8cf494cf066b912526ffbab7a85a460db9b0c4b1217a9040ca0285435905ed50626eb8c7036c73aa4fe8a65f2eca3ee23957bcd2563a7f0c
7
+ data.tar.gz: c65518af9ab3c4beee883147a93a50edcd2884d65f27d1d939245c8e13895a2508f899f65f281e5efc8f4a2059cfc0b451a5922fbc8c80f939b90dac4c211bbb
@@ -9,12 +9,12 @@ module Merit
9
9
  def copy_migrations_and_model
10
10
  template 'merit.erb', 'config/initializers/merit.rb'
11
11
  sleep 1.1
12
- template 'qalam_sash.erb', 'app/models/merit/qalam_sash.rb'
13
- sleep 1.1
12
+ # template 'qalam_sash.erb', 'app/models/merit/qalam_sash.rb'
13
+ # sleep 1.1
14
14
  template 'badge.erb', 'app/models/merit/badge.rb'
15
15
  sleep 1.1
16
- template 'qalam_badge_sash.erb', 'app/models/merit/qalam_badge_sash.rb'
17
- sleep 1.1
16
+ # template 'qalam_badge_sash.erb', 'app/models/merit/qalam_badge_sash.rb'
17
+ # sleep 1.1
18
18
  template 'merit_badge_rules.erb', 'app/models/merit/badge_rules.rb'
19
19
  sleep 1.1
20
20
  template 'merit_point_rules.erb', 'app/models/merit/point_rules.rb'
@@ -9,7 +9,7 @@ module Merit
9
9
  if model_exists?
10
10
  inject_into_class(model_path, class_name, " ### END ###\n\n")
11
11
  inject_into_class(model_path, class_name, " has_many :created_badges, class_name: 'Merit::Badge'\n")
12
- inject_into_class(model_path, class_name, " belongs_to :sash, foreign_key: 'sash_id', class_name: 'Merit::QalamSash'\n")
12
+ inject_into_class(model_path, class_name, " belongs_to :sash, foreign_key: 'sash_id', class_name: 'Merit::Sash'\n")
13
13
  inject_into_class(model_path, class_name, " has_merit\n")
14
14
  inject_into_class(model_path, class_name, " ### QALAM_MERIT ###\n")
15
15
  end
@@ -1,7 +1,8 @@
1
1
  module Merit::Models::ActiveRecord
2
2
  class BadgesSash < ActiveRecord::Base
3
3
  include Merit::Models::BadgesSashConcern
4
-
4
+ belongs_to :badge, foreign_key: "badge_id", class_name: 'Merit::Badge'
5
+ belongs_to :sash, foreign_key: "sash_id", class_name: 'Merit::Sash'
5
6
  has_many :activity_logs,
6
7
  class_name: 'Merit::ActivityLog',
7
8
  as: :related_change
@@ -1,17 +1,17 @@
1
1
  module Merit::Models::ActiveRecord
2
- class Score < ActiveRecord::Base
2
+ class QalamScore < ActiveRecord::Base
3
3
  self.table_name = :merit_scores
4
4
  belongs_to :sash
5
5
  has_many :score_points,
6
6
  dependent: :destroy,
7
- class_name: 'Merit::Score::Point'
7
+ class_name: 'Merit::QalamScore::Point'
8
8
 
9
9
  def points
10
10
  score_points.group(:score_id).sum(:num_points).values.first || 0
11
11
  end
12
12
 
13
13
  class Point < ActiveRecord::Base
14
- belongs_to :score, class_name: 'Merit::Score'
14
+ belongs_to :score, class_name: 'Merit::QalamScore'
15
15
  has_one :sash, through: :score
16
16
  has_many :activity_logs,
17
17
  class_name: 'Merit::ActivityLog',
@@ -21,5 +21,5 @@ module Merit::Models::ActiveRecord
21
21
  end
22
22
  end
23
23
 
24
- class Merit::Score < Merit::Models::ActiveRecord::Score; end
25
- class Merit::Score::Point < Merit::Models::ActiveRecord::Score::Point; end
24
+ class Merit::QalamScore < Merit::Models::ActiveRecord::QalamScore; end
25
+ class Merit::QalamScore::Point < Merit::Models::ActiveRecord::QalamScore::Point; end
@@ -7,9 +7,11 @@ module Merit::Models::ActiveRecord
7
7
  # unnecessary. It should be transparent at the application.
8
8
  class Sash < ActiveRecord::Base
9
9
  include Merit::Models::SashConcern
10
+ self.table_name = "sashes"
10
11
 
11
12
  has_many :badges_sashes, dependent: :destroy
12
- has_many :scores, dependent: :destroy, class_name: 'Merit::Score'
13
+ has_many :badges, through: :badges_sashes, source: :badge
14
+ has_many :scores, dependent: :destroy, class_name: 'Merit::QalamScore'
13
15
 
14
16
  after_create :create_scores
15
17
 
@@ -18,7 +20,7 @@ module Merit::Models::ActiveRecord
18
20
  # @param category [String] The category
19
21
  # @return [ActiveRecord::Relation] containing the points
20
22
  def score_points(options = {})
21
- scope = Merit::Score::Point
23
+ scope = Merit::QalamScore::Point
22
24
  .joins(:score)
23
25
  .where('merit_scores.sash_id = ?', id)
24
26
  if (category = options[:category])
@@ -32,7 +32,7 @@ module Merit
32
32
  end
33
33
 
34
34
  def add_points(num_points, options = {})
35
- point = Merit::Score::Point.new
35
+ point = Merit::QalamScore::Point.new
36
36
  point.num_points = num_points
37
37
  scores
38
38
  .where(category: options[:category] || 'default')
@@ -48,7 +48,7 @@ module Merit
48
48
  private
49
49
 
50
50
  def create_scores
51
- scores << Merit::Score.create
51
+ scores << Merit::QalamScore.create
52
52
  end
53
53
  end
54
54
  end
@@ -31,7 +31,7 @@ module Merit::Models
31
31
  end
32
32
 
33
33
  def add_points(num_points, options = {})
34
- point = Merit::Score::Point.new
34
+ point = Merit::QalamScore::Point.new
35
35
  point.num_points = num_points
36
36
  scores
37
37
  .where(category: options[:category] || 'default')
@@ -47,7 +47,7 @@ module Merit::Models
47
47
  private
48
48
 
49
49
  def create_scores
50
- scores << Merit::Score.create
50
+ scores << Merit::QalamScore.create
51
51
  end
52
52
  end
53
53
  end
data/qalam_merit.gemspec CHANGED
@@ -6,7 +6,7 @@ Gem::Specification.new do |s|
6
6
  s.files = `git ls-files`.split("\n").reject{|f| f =~ /^\./ }
7
7
  s.test_files = `git ls-files -- test/*`.split("\n")
8
8
  s.license = 'MIT'
9
- s.version = '4.0.4'
9
+ s.version = '4.5.03'
10
10
  s.authors = ["Tute Costa", "Ahmed Abdelhamid"]
11
11
  s.email = ['tutecosta@gmail.com', 'a.hamid@nezam.io']
12
12
 
@@ -107,12 +107,12 @@ class NavigationTest < ActionDispatch::IntegrationTest
107
107
  assert user.badges.empty?, 'Should not have badges'
108
108
 
109
109
  assert_equal 0, user.points
110
- assert_equal 0, Merit::Score::Point.count
110
+ assert_equal 0, Merit::QalamScore::Point.count
111
111
  user.add_points 15
112
112
  assert_equal 15, user.points
113
113
  user.subtract_points 15
114
114
  assert_equal 0, user.points
115
- assert_equal 2, Merit::Score::Point.count
115
+ assert_equal 2, Merit::QalamScore::Point.count
116
116
 
117
117
  # Tenth comment with errors doesn't change reputation
118
118
  badges = user.reload.badges
@@ -1,11 +1,11 @@
1
1
  require 'test_helper'
2
2
 
3
- describe Merit::Score do
3
+ describe Merit::QalamScore do
4
4
  it 'Point#sash_id delegates to Score' do
5
- score = Merit::Score.new
5
+ score = Merit::QalamScore.new
6
6
  score.sash_id = 33
7
7
 
8
- point = Merit::Score::Point.new
8
+ point = Merit::QalamScore::Point.new
9
9
  point.score = score
10
10
 
11
11
  _(point.sash_id).must_be :==, score.sash_id
@@ -10,7 +10,7 @@ class SashTest < ActiveSupport::TestCase
10
10
  describe "when category specified" do
11
11
  it "should create a new Point with specified category" do
12
12
  @sash.add_points 5, category: @custom_category
13
- score = Merit::Score.last
13
+ score = Merit::QalamScore.last
14
14
  point = score.score_points.last
15
15
 
16
16
  assert_equal point.num_points, 5
@@ -19,10 +19,10 @@ class SashTest < ActiveSupport::TestCase
19
19
  end
20
20
 
21
21
  it "should create a new Point in category default with specified number of points" do
22
- assert_difference("Merit::Score::Point.count", 1) do
22
+ assert_difference("Merit::QalamScore::Point.count", 1) do
23
23
  @sash.add_points 5
24
24
  end
25
- score = Merit::Score.last
25
+ score = Merit::QalamScore.last
26
26
  point = score.score_points.last
27
27
 
28
28
  assert_equal point.num_points, 5
@@ -34,7 +34,7 @@ class SashTest < ActiveSupport::TestCase
34
34
  describe "when category specified" do
35
35
  it "should create a new Point with specified category" do
36
36
  @sash.subtract_points 5, category: @custom_category
37
- score = Merit::Score.last
37
+ score = Merit::QalamScore.last
38
38
  point = score.score_points.last
39
39
 
40
40
  assert_equal point.num_points, -5
@@ -43,10 +43,10 @@ class SashTest < ActiveSupport::TestCase
43
43
  end
44
44
 
45
45
  it "should create a new Point in category default with inverse of specified number of points" do
46
- assert_difference("Merit::Score::Point.count", 1) do
46
+ assert_difference("Merit::QalamScore::Point.count", 1) do
47
47
  @sash.subtract_points 5
48
48
  end
49
- score = Merit::Score.last
49
+ score = Merit::QalamScore.last
50
50
  point = score.score_points.last
51
51
 
52
52
  assert_equal point.num_points, -5
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: qalam_merit
3
3
  version: !ruby/object:Gem::Version
4
- version: 4.0.4
4
+ version: 4.5.03
5
5
  platform: ruby
6
6
  authors:
7
7
  - Tute Costa
@@ -9,7 +9,7 @@ authors:
9
9
  autorequire:
10
10
  bindir: bin
11
11
  cert_chain: []
12
- date: 2021-02-21 00:00:00.000000000 Z
12
+ date: 2021-02-28 00:00:00.000000000 Z
13
13
  dependencies:
14
14
  - !ruby/object:Gem::Dependency
15
15
  name: zeitwerk
@@ -158,8 +158,8 @@ files:
158
158
  - lib/merit/models/active_record/action.rb
159
159
  - lib/merit/models/active_record/activity_log.rb
160
160
  - lib/merit/models/active_record/badges_sash.rb
161
+ - lib/merit/models/active_record/qalam_score.rb
161
162
  - lib/merit/models/active_record/sash.rb
162
- - lib/merit/models/active_record/score.rb
163
163
  - lib/merit/models/badges_sash_concern.rb
164
164
  - lib/merit/models/base/badges_sash.rb
165
165
  - lib/merit/models/base/sash.rb
@@ -247,11 +247,11 @@ files:
247
247
  - test/unit/action_test.rb
248
248
  - test/unit/base_target_finder_test.rb
249
249
  - test/unit/merit_unit_test.rb
250
+ - test/unit/qalam_score_test.rb
250
251
  - test/unit/rule_unit_test.rb
251
252
  - test/unit/rules_matcher_test.rb
252
253
  - test/unit/sash_finder_test.rb
253
254
  - test/unit/sash_test.rb
254
- - test/unit/score_test.rb
255
255
  - test/unit/target_finder_test.rb
256
256
  homepage: https://github.com/merit-gem/merit
257
257
  licenses:
@@ -352,9 +352,9 @@ test_files:
352
352
  - test/unit/action_test.rb
353
353
  - test/unit/base_target_finder_test.rb
354
354
  - test/unit/merit_unit_test.rb
355
+ - test/unit/qalam_score_test.rb
355
356
  - test/unit/rule_unit_test.rb
356
357
  - test/unit/rules_matcher_test.rb
357
358
  - test/unit/sash_finder_test.rb
358
359
  - test/unit/sash_test.rb
359
- - test/unit/score_test.rb
360
360
  - test/unit/target_finder_test.rb