flipper-active_record 1.3.2 → 1.3.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 75b48b94a5b6100e328025853743e12db745d9d862421035821e4a2a351355bc
4
- data.tar.gz: a02ebf011fa0786f273a2279ac7f55cffe41f7869b84db61ff16e6eb9d3de2a6
3
+ metadata.gz: ae15abe1a25ef415ec5f7783b24192ae52cbf86b6d8e8026a7b23d3182db2ea3
4
+ data.tar.gz: 92c793efbd0539545f73d363f61df2f3a43d949aafb0bb303ecb5d8a747e660a
5
5
  SHA512:
6
- metadata.gz: 490824ee74e62f12e676c76368e8f4746339909ed77208be8b0686ced9f8d4bdc0ee8c0c4be110ba1dd94de172bdd0baf05edfcec0344a240a0ffa05ee3a6352
7
- data.tar.gz: a1eddef416ddf2ea95b02b09b018958dd488da5d04fb0aae04f3ce31b789e1072eaae1e2763b495f1e795880667dabcfcf24adb5baf69ddb47209c8e3fa5da4c
6
+ metadata.gz: a01ae2b84eea1af1a46ed86a0727a38418ec88682fddf0e8829e340f39e368adf7e3451e07b05efc423d874cc6bf70910bfc7afe61267db84c6e8ef90d6f1764
7
+ data.tar.gz: 280adedbab88143432826be99f65e17673f9bc0012ddb4c89392b32c6dd2c6ec9ce71a68bf1f79dce2347a631afc5d0f3804092ddbd2d6ef6906fb2af6142534
@@ -28,3 +28,18 @@ SQL
28
28
  ActiveRecord::Base.connection.execute <<-SQL
29
29
  CREATE UNIQUE INDEX index_gates_on_keys_and_value on flipper_gates (feature_key, key, value)
30
30
  SQL
31
+
32
+ ActiveRecord::Base.connection.execute <<-SQL
33
+ CREATE TABLE users (
34
+ id integer PRIMARY KEY,
35
+ name string NOT NULL,
36
+ influencer boolean,
37
+ created_at datetime NOT NULL,
38
+ updated_at datetime NOT NULL
39
+ )
40
+ SQL
41
+
42
+ require 'flipper/model/active_record'
43
+ class User < ActiveRecord::Base
44
+ include Flipper::Model::ActiveRecord
45
+ end
@@ -0,0 +1,68 @@
1
+ # This is an example script that shows how to migrate from a bunch of individual
2
+ # actors to a group. Should be useful for those who have ended up with large
3
+ # actor sets and want to slim them down for performance reasons.
4
+
5
+ require_relative "./ar_setup"
6
+ require 'flipper/adapters/active_record'
7
+ require 'active_support/all'
8
+
9
+ # 1. enable feature for 100 actors, make 80 influencers
10
+ users = 100.times.map do |n|
11
+ influencer = n < 80 ? true : false
12
+ user = User.create(name: n, influencer: influencer)
13
+ Flipper.enable :stats, user
14
+ user
15
+ end
16
+
17
+ # check enabled, should all be because individual actors are enabled
18
+ print 'Should be [[true, 100]]: '
19
+ print users.group_by { |user| Flipper.enabled?(:stats, user) }.map { |result, users| [result, users.size]}
20
+ puts
21
+
22
+ # 2. register a group so flipper knows what to do with it
23
+ Flipper.register(:influencers) do |actor, context|
24
+ actor.respond_to?(:influencer) && actor.influencer
25
+ end
26
+
27
+ # 3. enable group for feature, THIS IS IMPORTANT
28
+ Flipper.enable :stats, :influencers
29
+
30
+ # check enabled again, should all still be true because individual actors are
31
+ # enabled, but also the group gate would return true for 80 influencers. At this
32
+ # point, it's kind of double true but flipper just cares if any gate returns true.
33
+ print 'Should be [[true, 100]]: '
34
+ print users.group_by { |user| Flipper.enabled?(:stats, user) }.map { |result, users| [result, users.size]}
35
+ puts
36
+
37
+ # 4. now we want to clean up the actors that are covered by the group to slim down
38
+ # the actor set size. So we loop through actors and remove them if group returns
39
+ # true for the provided actor and context.
40
+ Flipper[:stats].actors_value.each do |flipper_id|
41
+ # Hydrate the flipper_id into an active record object. Modify this based on
42
+ # your flipper_id's if you use anything other than active record models and
43
+ # the default flipper_id provided by flipper.
44
+ class_name, id = flipper_id.split(';')
45
+ klass = class_name.constantize
46
+ user = klass.find(id)
47
+
48
+ # if user is in group then disable for actor because they'll still get the feature
49
+ context = Flipper::FeatureCheckContext.new(
50
+ feature_name: :stats,
51
+ values: Flipper[:stats].gate_values,
52
+ actors: [Flipper::Types::Actor.wrap(user)]
53
+ )
54
+
55
+ if Flipper::Gates::Group.new.open?(context)
56
+ Flipper.disable(:stats, user)
57
+ end
58
+ end
59
+
60
+ # check enabled again, should be the same result as previous checks
61
+ print 'Should be [[true, 100]]: '
62
+ print users.group_by { |user| Flipper.enabled?(:stats, user) }.map { |result, users| [result, users.size]}
63
+ puts
64
+
65
+ puts "Actors enabled: #{Flipper[:stats].actors_value.size}"
66
+ puts "Groups enabled: #{Flipper[:stats].groups_value.size}"
67
+
68
+ puts "All actors that could be migrated to groups were migrated. Yay!"
@@ -1,5 +1,5 @@
1
1
  module Flipper
2
- VERSION = '1.3.2'.freeze
2
+ VERSION = '1.3.4'.freeze
3
3
 
4
4
  REQUIRED_RUBY_VERSION = '2.6'.freeze
5
5
  NEXT_REQUIRED_RUBY_VERSION = '3.0'.freeze
@@ -9,9 +9,10 @@ RSpec.describe Flipper::Adapters::ActiveRecord do
9
9
 
10
10
  before(:all) do
11
11
  # Eval migration template so we can run migration against each database
12
- migration = ERB.new(File.read(File.join(File.dirname(__FILE__), '../../../lib/generators/flipper/templates/migration.erb')))
12
+ template_path = File.join(File.dirname(__FILE__), '../../../lib/generators/flipper/templates/migration.erb')
13
+ migration = ERB.new(File.read(template_path))
13
14
  migration_version = "[#{ActiveRecord::VERSION::MAJOR}.#{ActiveRecord::VERSION::MINOR}]"
14
- eval migration.result(binding) # defines CreateFlipperTables
15
+ eval migration.result_with_hash(migration_version: migration_version) # defines CreateFlipperTables
15
16
  end
16
17
 
17
18
  [
@@ -52,8 +53,10 @@ RSpec.describe Flipper::Adapters::ActiveRecord do
52
53
  end
53
54
 
54
55
  before(:each) do
55
- ActiveRecord::Tasks::DatabaseTasks.purge(config)
56
- CreateFlipperTables.migrate(:up)
56
+ silence do
57
+ ActiveRecord::Tasks::DatabaseTasks.purge(config)
58
+ CreateFlipperTables.migrate(:up)
59
+ end
57
60
  end
58
61
 
59
62
  after(:all) do
metadata CHANGED
@@ -1,14 +1,13 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: flipper-active_record
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.3.2
4
+ version: 1.3.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - John Nunemaker
8
- autorequire:
9
8
  bindir: bin
10
9
  cert_chain: []
11
- date: 2024-11-19 00:00:00.000000000 Z
10
+ date: 2025-03-03 00:00:00.000000000 Z
12
11
  dependencies:
13
12
  - !ruby/object:Gem::Dependency
14
13
  name: flipper
@@ -16,14 +15,14 @@ dependencies:
16
15
  requirements:
17
16
  - - "~>"
18
17
  - !ruby/object:Gem::Version
19
- version: 1.3.2
18
+ version: 1.3.4
20
19
  type: :runtime
21
20
  prerelease: false
22
21
  version_requirements: !ruby/object:Gem::Requirement
23
22
  requirements:
24
23
  - - "~>"
25
24
  - !ruby/object:Gem::Version
26
- version: 1.3.2
25
+ version: 1.3.4
27
26
  - !ruby/object:Gem::Dependency
28
27
  name: activerecord
29
28
  requirement: !ruby/object:Gem::Requirement
@@ -44,7 +43,6 @@ dependencies:
44
43
  - - "<"
45
44
  - !ruby/object:Gem::Version
46
45
  version: '9'
47
- description:
48
46
  email: support@flippercloud.io
49
47
  executables: []
50
48
  extensions: []
@@ -56,6 +54,7 @@ files:
56
54
  - examples/active_record/ar_setup.rb
57
55
  - examples/active_record/basic.rb
58
56
  - examples/active_record/cached.rb
57
+ - examples/active_record/group_migration.rb
59
58
  - examples/active_record/internals.rb
60
59
  - flipper-active_record.gemspec
61
60
  - lib/flipper-active_record.rb
@@ -74,8 +73,8 @@ metadata:
74
73
  homepage_uri: https://www.flippercloud.io
75
74
  source_code_uri: https://github.com/flippercloud/flipper
76
75
  bug_tracker_uri: https://github.com/flippercloud/flipper/issues
77
- changelog_uri: https://github.com/flippercloud/flipper/releases/tag/v1.3.2
78
- post_install_message:
76
+ changelog_uri: https://github.com/flippercloud/flipper/releases/tag/v1.3.4
77
+ funding_uri: https://github.com/sponsors/flippercloud
79
78
  rdoc_options: []
80
79
  require_paths:
81
80
  - lib
@@ -90,8 +89,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
90
89
  - !ruby/object:Gem::Version
91
90
  version: '0'
92
91
  requirements: []
93
- rubygems_version: 3.5.23
94
- signing_key:
92
+ rubygems_version: 3.6.5
95
93
  specification_version: 4
96
94
  summary: ActiveRecord feature flag adapter for Flipper
97
95
  test_files: