execution_time 0.1.2 → 0.1.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 +4 -4
- data/README.md +19 -1
- data/lib/execution_time/version.rb +1 -1
- data/lib/execution_time.rb +6 -2
- metadata +34 -6
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: fdf5b2936b0ba018e9d552f58a688e42c8fd687d909d7f0ebda250073cb8f65e
|
4
|
+
data.tar.gz: b786631413bff61f616d7b178a5ff271b1c58280ad56d540aad64ff0304fae93
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 98189559f4ae66c349537799b7e7562c189c427174d86c6481ae6e1b5b23fa73e2d9697d911aa9ec45ea728210aca85be4aba7c4e8372b20dd2ef8a68b2b90e4
|
7
|
+
data.tar.gz: a962c753502dac4140d77f0ff2992051ee9875de5c3c79717e805b32aa3a2967a4a0a9e97755001873f21cdafbce729f0490d6d9cdf0164d255515faeadef551
|
data/README.md
CHANGED
@@ -1,5 +1,7 @@
|
|
1
1
|
# ExecutionTime
|
2
2
|
|
3
|
+
[](https://opensource-heroes.com/r/igorkasyanchuk/execution_time)
|
4
|
+
|
3
5
|
Monitor execution time and other metrics directly in `rails console`, similar to what you see after each request.
|
4
6
|
|
5
7
|
`[METRICS] Completed in 908.3ms | Allocations: 2894 | ActiveRecord: 0.9ms (queries: 13)`
|
@@ -10,7 +12,20 @@ Monitor execution time and other metrics directly in `rails console`, similar to
|
|
10
12
|
|
11
13
|
Just add this gem to the Gemfile and start `rails c`. After this try to do something like `User.first`.
|
12
14
|
|
13
|
-
If you want to measure few lines of code just wrap it with `begin/end
|
15
|
+
If you want to measure few lines of code just wrap it with `begin/end`:
|
16
|
+
|
17
|
+
```ruby
|
18
|
+
[4] pry(main)> begin
|
19
|
+
[4] pry(main)* User.first.first_name.size
|
20
|
+
[4] pry(main)* a = User.count + 1
|
21
|
+
[4] pry(main)* b = User.second.last_name.size
|
22
|
+
[4] pry(main)* end
|
23
|
+
User Load (0.4ms) SELECT "users".* FROM "users" ORDER BY "users"."id" ASC LIMIT $1 [["LIMIT", 1]]
|
24
|
+
(3.6ms) SELECT COUNT(*) FROM "users"
|
25
|
+
User Load (0.3ms) SELECT "users".* FROM "users" ORDER BY "users"."id" ASC LIMIT $1 OFFSET $2 [["LIMIT", 1], ["OFFSET", 1]]
|
26
|
+
[METRICS] Completed in 6.8ms | Allocations: 839 | ActiveRecord: 4.3ms (queries: 3)
|
27
|
+
=> 5
|
28
|
+
```
|
14
29
|
|
15
30
|
## Installation
|
16
31
|
|
@@ -41,3 +56,6 @@ You are welcome to contribute.
|
|
41
56
|
|
42
57
|
## License
|
43
58
|
The gem is available as open source under the terms of the [MIT License](https://opensource.org/licenses/MIT).
|
59
|
+
|
60
|
+
[<img src="https://github.com/igorkasyanchuk/rails_time_travel/blob/main/docs/more_gems.png?raw=true"
|
61
|
+
/>](https://www.railsjazz.com/?utm_source=github&utm_medium=bottom&utm_campaign=execution_time)
|
data/lib/execution_time.rb
CHANGED
@@ -72,7 +72,11 @@ module ExecutionTime
|
|
72
72
|
module IrbContextExt
|
73
73
|
def evaluate(*args)
|
74
74
|
Measurer.watch do
|
75
|
-
|
75
|
+
if RUBY_VERSION.to_s =~ /^3/ && !args[2].nil?
|
76
|
+
super(args[0], args[1], **args[2])
|
77
|
+
else
|
78
|
+
super(*args)
|
79
|
+
end
|
76
80
|
end
|
77
81
|
end
|
78
82
|
end
|
@@ -95,4 +99,4 @@ module ExecutionTime
|
|
95
99
|
super(code)
|
96
100
|
end
|
97
101
|
end
|
98
|
-
end
|
102
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: execution_time
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Igor Kasyanchuk
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2023-07-10 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -38,6 +38,34 @@ dependencies:
|
|
38
38
|
- - ">="
|
39
39
|
- !ruby/object:Gem::Version
|
40
40
|
version: '0'
|
41
|
+
- !ruby/object:Gem::Dependency
|
42
|
+
name: irb
|
43
|
+
requirement: !ruby/object:Gem::Requirement
|
44
|
+
requirements:
|
45
|
+
- - ">="
|
46
|
+
- !ruby/object:Gem::Version
|
47
|
+
version: '0'
|
48
|
+
type: :development
|
49
|
+
prerelease: false
|
50
|
+
version_requirements: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - ">="
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '0'
|
55
|
+
- !ruby/object:Gem::Dependency
|
56
|
+
name: pry
|
57
|
+
requirement: !ruby/object:Gem::Requirement
|
58
|
+
requirements:
|
59
|
+
- - ">="
|
60
|
+
- !ruby/object:Gem::Version
|
61
|
+
version: '0'
|
62
|
+
type: :development
|
63
|
+
prerelease: false
|
64
|
+
version_requirements: !ruby/object:Gem::Requirement
|
65
|
+
requirements:
|
66
|
+
- - ">="
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: '0'
|
41
69
|
description: Measure execution time in Rails console
|
42
70
|
email:
|
43
71
|
- igorkasyanchuk@gmail.com
|
@@ -56,7 +84,7 @@ homepage: https://github.com/igorkasyanchuk
|
|
56
84
|
licenses:
|
57
85
|
- MIT
|
58
86
|
metadata: {}
|
59
|
-
post_install_message:
|
87
|
+
post_install_message:
|
60
88
|
rdoc_options: []
|
61
89
|
require_paths:
|
62
90
|
- lib
|
@@ -71,8 +99,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
71
99
|
- !ruby/object:Gem::Version
|
72
100
|
version: '0'
|
73
101
|
requirements: []
|
74
|
-
rubygems_version: 3.
|
75
|
-
signing_key:
|
102
|
+
rubygems_version: 3.4.13
|
103
|
+
signing_key:
|
76
104
|
specification_version: 4
|
77
105
|
summary: Measure execution time in Rails console
|
78
106
|
test_files: []
|