philiprehberger-random_data 0.4.0 → 0.5.0

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: 66b3892c4c67cf116d9f415c2f15f9351e9fc9ecc907fcd052d93db04c2da69c
4
- data.tar.gz: 25f7bd4d5907d4350dc5d9381781b6c47f694e4df593c48ef80347147fd97ad8
3
+ metadata.gz: 50f3c7612e67e7214cf57ff2af61567a21efad6111cad8d097801e13fa49b46d
4
+ data.tar.gz: 718650040993a0556ce4185768c577fcd74aa221dfcf46e222c9ed8108798347
5
5
  SHA512:
6
- metadata.gz: 4ea172d1596e1f5c28aa06cef63822fec2202f4a176c526f4f132a5aedd13bbb0db6bda54740ef11fbfbbafb6242e7b2693cc22f89e1a547fb09cf3fa241ccd7
7
- data.tar.gz: 127842bc07223d27f397348d79ebec2dda96e32a588b13119748070bb89054b9719714e6744c33a3b0e57df82eda1eca154c7ebc116474a628e397e3da611367
6
+ metadata.gz: db0d5224d4442603652a0ad80bbba172ccc9045d1916a2745d798e1ed24456e36726cd8b1060b864d3afa29bb40d01240ec5281160e5ab466e73f7ed903283c9
7
+ data.tar.gz: e2cf5bc488ef1d5297778d0821a3c755db65924bbacd06a39bb6b62f28a13deb867c10647a120d3973e77df0d05a3360a292612e744f801572f6b1fdd2dbcde9
data/CHANGELOG.md CHANGED
@@ -7,6 +7,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [0.5.0] - 2026-04-27
11
+
12
+ ### Added
13
+ - `RandomData.array(of:, size:, **opts)` — generate `size` items by repeatedly calling the named generator; forwards keyword options on every call. Raises `Error` for unknown generator names or negative size.
14
+ - `RandomData.seed!(value)` — seeds Ruby's PRNG for deterministic output across subsequent generators (useful for reproducible test runs and golden-file fixtures). `uuid` and `hex` use `SecureRandom` and are not affected.
15
+
10
16
  ## [0.4.0] - 2026-04-24
11
17
 
12
18
  ### Added
data/README.md CHANGED
@@ -103,6 +103,33 @@ Philiprehberger::RandomData.password(length: 8, symbols: false) # => "kQ7mR2nP"
103
103
  Philiprehberger::RandomData.timestamp # => 2025-08-14 03:22:11 +0000
104
104
  ```
105
105
 
106
+ ### Bulk Generation
107
+
108
+ `array` calls a generator `size` times and forwards options on every call.
109
+
110
+ ```ruby
111
+ Philiprehberger::RandomData.array(of: :email, size: 3)
112
+ # => ["alice.smith@example.com", "bob_jones@test.com", "carol.lee@demo.com"]
113
+
114
+ Philiprehberger::RandomData.array(of: :integer, size: 5, range: 1..10)
115
+ # => [3, 8, 1, 6, 9]
116
+
117
+ Philiprehberger::RandomData.array(of: :address, size: 2)
118
+ # => [{ street: ..., city: ..., state: ..., zip: ... }, ...]
119
+ ```
120
+
121
+ ### Deterministic Output
122
+
123
+ Seed Ruby's PRNG so subsequent calls produce a deterministic sequence. Useful
124
+ for reproducible test runs and golden-file fixtures. `uuid` and `hex` use
125
+ `SecureRandom` and are not affected.
126
+
127
+ ```ruby
128
+ Philiprehberger::RandomData.seed!(42)
129
+ Philiprehberger::RandomData.integer(1..100) # => deterministic value
130
+ Philiprehberger::RandomData.integer(1..100) # => deterministic next value
131
+ ```
132
+
106
133
  ## API
107
134
 
108
135
  | Method | Description |
@@ -131,6 +158,8 @@ Philiprehberger::RandomData.timestamp # => 2025-08-14 03:22:11 +0000
131
158
  | `RandomData.color` | Random hex color string |
132
159
  | `RandomData.password(length:, symbols:)` | Random password |
133
160
  | `RandomData.timestamp(range)` | Random Time object |
161
+ | `RandomData.array(of:, size:, **opts)` | Generate `size` items by repeatedly calling the named generator; forwards `opts` |
162
+ | `RandomData.seed!(value)` | Seed Ruby's PRNG so subsequent generators are deterministic; returns the previous seed |
134
163
 
135
164
  ## Development
136
165
 
@@ -2,6 +2,6 @@
2
2
 
3
3
  module Philiprehberger
4
4
  module RandomData
5
- VERSION = '0.4.0'
5
+ VERSION = '0.5.0'
6
6
  end
7
7
  end
@@ -223,5 +223,40 @@ module Philiprehberger
223
223
  Time.now - rand(0..(365 * 24 * 60 * 60))
224
224
  end
225
225
  end
226
+
227
+ # Generate an array of `size` items by repeatedly calling the named generator.
228
+ # Extra options are forwarded to the generator on every call.
229
+ #
230
+ # @example
231
+ # RandomData.array(of: :email, size: 3)
232
+ # RandomData.array(of: :integer, size: 5, range: 1..10)
233
+ #
234
+ # @param of [Symbol] generator method name (must be a public method on this module other than `array`)
235
+ # @param size [Integer] number of items to generate (must be >= 0)
236
+ # @param opts [Hash] keyword arguments forwarded to the generator
237
+ # @return [Array] generated items
238
+ # @raise [Error] if `of` is not a known generator or `size` is negative
239
+ def self.array(of:, size:, **opts)
240
+ raise Error, 'size must be a non-negative Integer' unless size.is_a?(Integer) && size >= 0
241
+ raise Error, "unknown generator: #{of}" unless of != :array && respond_to?(of)
242
+
243
+ Array.new(size) do
244
+ opts.empty? ? public_send(of) : public_send(of, **opts)
245
+ end
246
+ end
247
+
248
+ # Seed Ruby's PRNG so subsequent generators produce a deterministic sequence.
249
+ # Useful for reproducible test runs and golden-file fixtures. Note that methods
250
+ # using `SecureRandom` (`uuid`, `hex`) are not affected — they read from the
251
+ # OS CSPRNG.
252
+ #
253
+ # @param value [Integer] seed value
254
+ # @return [Integer] the previous seed
255
+ # @raise [Error] if `value` is not an Integer
256
+ def self.seed!(value)
257
+ raise Error, 'seed must be an Integer' unless value.is_a?(Integer)
258
+
259
+ Kernel.srand(value)
260
+ end
226
261
  end
227
262
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: philiprehberger-random_data
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.4.0
4
+ version: 0.5.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Philip Rehberger
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2026-04-24 00:00:00.000000000 Z
11
+ date: 2026-04-28 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: Generate random test data including names, emails, phone numbers, UUIDs,
14
14
  sentences, paragraphs, dates, numbers, and more. Includes 50 first names, 50 last