speedos 0.0.11 → 0.0.12
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.rspec +1 -0
- data/Gemfile +1 -0
- data/Gemfile.lock +9 -1
- data/README.md +6 -1
- data/lib/speedos.rb +1 -0
- data/lib/speedos/models/entries.rb +25 -9
- data/lib/speedos/models/information.rb +13 -0
- data/lib/speedos/models/record.rb +12 -6
- data/lib/speedos/performance.rb +6 -1
- data/spec/lib/entries_spec.rb +67 -15
- data/spec/models/record_spec.rb +29 -0
- data/spec/spec_helper.rb +5 -2
- data/speedos.gemspec +1 -1
- metadata +4 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 34abd33e531b6cff88c5fd2d4c377e86550d52a5
|
4
|
+
data.tar.gz: 85a162069d09232d2c2a744ef912704971584fc7
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: a24f7edce7176c3a2cb7a735512b6c71d01822cde282e1d434afbd92c5f631c883059c613b183525dd90977ad0a6c3fd7f78dad000f8bd4ab77ca9af17db34b6
|
7
|
+
data.tar.gz: 0b855b99e810e716936e29901a01201bf01bdadfc46038821cd29ccb1c36179201716c1d625e019561cd6b0a2a5a656db3cc3470aed7243d6e8cc6aed51552d6
|
data/.rspec
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
--color
|
data/Gemfile
CHANGED
data/Gemfile.lock
CHANGED
@@ -10,7 +10,7 @@ GIT
|
|
10
10
|
PATH
|
11
11
|
remote: .
|
12
12
|
specs:
|
13
|
-
speedos (0.0.
|
13
|
+
speedos (0.0.12)
|
14
14
|
browsermob-proxy (= 0.1.3)
|
15
15
|
capybara (= 2.1.0)
|
16
16
|
faker (= 1.1.2)
|
@@ -80,7 +80,14 @@ GEM
|
|
80
80
|
rspec-expectations (2.14.0)
|
81
81
|
diff-lcs (>= 1.1.3, < 2.0)
|
82
82
|
rspec-mocks (2.14.1)
|
83
|
+
rubyzip (0.9.9)
|
84
|
+
selenium-webdriver (2.35.1)
|
85
|
+
childprocess (>= 0.2.5)
|
86
|
+
multi_json (~> 1.0)
|
87
|
+
rubyzip (< 1.0.0)
|
88
|
+
websocket (~> 1.0.4)
|
83
89
|
tzinfo (0.3.37)
|
90
|
+
websocket (1.0.7)
|
84
91
|
xpath (2.0.0)
|
85
92
|
nokogiri (~> 1.3)
|
86
93
|
|
@@ -91,4 +98,5 @@ DEPENDENCIES
|
|
91
98
|
database_cleaner
|
92
99
|
har!
|
93
100
|
rspec
|
101
|
+
selenium-webdriver (= 2.35.1)
|
94
102
|
speedos!
|
data/README.md
CHANGED
@@ -4,10 +4,15 @@
|
|
4
4
|
Speedos incorporates [BrowserMob Proxy](http://bmp.lightbody.net) along with [Capybara](https://github.com/jnicklas/capybara), recording the web traffic and time taken to load all elements on each of the pages within a user journey. The aim is to identify any performance related issues, such as specific items that take a long time to load on page.
|
5
5
|
|
6
6
|
## Installation
|
7
|
-
Put speedos on your Gemfile
|
7
|
+
Put speedos on your Gemfile
|
8
8
|
|
9
9
|
gem 'speedos'
|
10
|
+
|
11
|
+
# MUST ADD: 'selenium-webdriver', '2.35.1'
|
10
12
|
gem 'har', git: 'https://github.com/PeterWuMC/har.git'
|
13
|
+
|
14
|
+
# OPTIONAL (if you want to use a properly working harviewer):
|
15
|
+
gem 'selenium-webdriver', '2.35.1'
|
11
16
|
|
12
17
|
Or, install it via rubygem
|
13
18
|
|
data/lib/speedos.rb
CHANGED
@@ -7,15 +7,7 @@ module Speedos
|
|
7
7
|
end
|
8
8
|
|
9
9
|
def total_load_time
|
10
|
-
earliest_start_time
|
11
|
-
latest_end_time = nil
|
12
|
-
@raw.each do |e|
|
13
|
-
start_time = Time.parse(e["startedDateTime"]).to_f * 1000
|
14
|
-
end_time = start_time + e["time"]
|
15
|
-
earliest_start_time = start_time if !earliest_start_time || earliest_start_time > start_time
|
16
|
-
latest_end_time = end_time if !latest_end_time || latest_end_time < end_time
|
17
|
-
end
|
18
|
-
(latest_end_time && earliest_start_time) ? (latest_end_time - earliest_start_time) : 0
|
10
|
+
(latest_end_time && earliest_start_time) ? (latest_end_time - earliest_start_time) * 1000 : 0
|
19
11
|
end
|
20
12
|
|
21
13
|
def name
|
@@ -25,5 +17,29 @@ module Speedos
|
|
25
17
|
def inspect
|
26
18
|
"Entries: #{name}"
|
27
19
|
end
|
20
|
+
|
21
|
+
def earliest_start_time
|
22
|
+
@earliest_start_time ||= begin
|
23
|
+
get_earliest_start_time_latest_end_time
|
24
|
+
earliest_start_time
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
def latest_end_time
|
29
|
+
@latest_end_time ||= begin
|
30
|
+
get_earliest_start_time_latest_end_time
|
31
|
+
latest_end_time
|
32
|
+
end
|
33
|
+
end
|
34
|
+
|
35
|
+
private
|
36
|
+
def get_earliest_start_time_latest_end_time
|
37
|
+
raw.each do |e|
|
38
|
+
start_time = Time.parse(e["startedDateTime"])
|
39
|
+
end_time = Time.at(start_time.to_f + (e["time"].to_f / 1000))
|
40
|
+
@earliest_start_time = start_time if !@earliest_start_time || @earliest_start_time > start_time
|
41
|
+
@latest_end_time = end_time if !@latest_end_time || @latest_end_time < end_time
|
42
|
+
end
|
43
|
+
end
|
28
44
|
end
|
29
45
|
end
|
@@ -3,6 +3,8 @@ module Speedos
|
|
3
3
|
include Mongoid::Document
|
4
4
|
include Mongoid::Timestamps
|
5
5
|
|
6
|
+
embeds_many :information
|
7
|
+
|
6
8
|
field :success, type: Boolean
|
7
9
|
field :log
|
8
10
|
|
@@ -24,12 +26,16 @@ module Speedos
|
|
24
26
|
File.open(filename, 'w') { |f| f.write({log: self.log}.to_json)}
|
25
27
|
end
|
26
28
|
|
27
|
-
def
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
29
|
+
def refresh_information
|
30
|
+
information = self.information
|
31
|
+
information.destroy_all
|
32
|
+
self.pages.each do |page|
|
33
|
+
information.create(
|
34
|
+
:page_name => page.name,
|
35
|
+
:began_at => page.earliest_start_time,
|
36
|
+
:finished_at => page.latest_end_time,
|
37
|
+
:total_duration => page.total_load_time
|
38
|
+
)
|
33
39
|
end
|
34
40
|
end
|
35
41
|
end
|
data/lib/speedos/performance.rb
CHANGED
@@ -14,9 +14,14 @@ module Speedos
|
|
14
14
|
Log.error("#{e.backtrace}")
|
15
15
|
success = false
|
16
16
|
ensure
|
17
|
-
|
17
|
+
finialise_record(JSON.load(page.get_har.to_json)['log'], success)
|
18
18
|
page.server_proxy.close
|
19
19
|
page.server.stop
|
20
20
|
end
|
21
|
+
|
22
|
+
def finialise_record(log, success)
|
23
|
+
record = Record.create(log: log, success: success)
|
24
|
+
record.refresh_information
|
25
|
+
end
|
21
26
|
end
|
22
27
|
end
|
data/spec/lib/entries_spec.rb
CHANGED
@@ -1,31 +1,83 @@
|
|
1
1
|
require 'spec_helper'
|
2
2
|
|
3
3
|
describe Speedos::Entries do
|
4
|
-
|
5
|
-
subject { Speedos::Entries }
|
4
|
+
describe '#get_earliest_start_time_latest_end_time' do
|
5
|
+
subject { Speedos::Entries.new(times) }
|
6
6
|
|
7
7
|
context 'when all tasks start the same time' do
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
{'startedDateTime' =>
|
12
|
-
|
13
|
-
|
8
|
+
let(:time) { Time.new(2012,1,1,12) }
|
9
|
+
let(:times) do
|
10
|
+
[
|
11
|
+
{'startedDateTime' => time.to_s, 'time' => 100},
|
12
|
+
{'startedDateTime' => time.to_s, 'time' => 50},
|
13
|
+
]
|
14
|
+
end
|
15
|
+
|
16
|
+
before { subject.send(:total_load_time) }
|
17
|
+
|
18
|
+
it 'updates earliest_start_time' do
|
19
|
+
subject.earliest_start_time.should eq time
|
20
|
+
end
|
21
|
+
|
22
|
+
it 'updates the latest_end_time' do
|
23
|
+
end_time = Time.at(time.to_f + 100.0/1000)
|
24
|
+
subject.latest_end_time.to_f.should eq end_time.to_f
|
14
25
|
end
|
15
26
|
end
|
16
27
|
|
17
28
|
context 'when tasks are started at the same time' do
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
29
|
+
let(:earlier_time) { Time.new(2012,1,1,12,0,0) }
|
30
|
+
let(:later_time) { Time.new(2012,1,1,12,0,1) }
|
31
|
+
let(:times) do
|
32
|
+
[
|
33
|
+
{'startedDateTime' => earlier_time.to_s, 'time' => 100},
|
34
|
+
{'startedDateTime' => later_time.to_s, 'time' => 50},
|
35
|
+
]
|
36
|
+
end
|
37
|
+
|
38
|
+
it 'updates the total time needed' do
|
39
|
+
subject.earliest_start_time.should eq earlier_time
|
40
|
+
end
|
41
|
+
|
42
|
+
it 'updates the latest_end_time' do
|
43
|
+
end_time = Time.at(later_time.to_f + 50.0/1000)
|
44
|
+
subject.latest_end_time.to_f.should eq end_time.to_f
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
describe '#total_load_time' do
|
50
|
+
subject { Speedos::Entries.new(double) }
|
51
|
+
|
52
|
+
let(:earliest_start_time) { Time.current }
|
53
|
+
let(:latest_end_time) { Time.current }
|
54
|
+
|
55
|
+
before do
|
56
|
+
subject.stub(:earliest_start_time).and_return(earliest_start_time)
|
57
|
+
subject.stub(:latest_end_time).and_return(latest_end_time)
|
58
|
+
end
|
59
|
+
|
60
|
+
context 'when either latest_end_time or earliest_start_time is empty' do
|
61
|
+
context 'when either latest_end_time is nil' do
|
62
|
+
let(:earliest_start_time) { nil }
|
63
|
+
its(:total_load_time) { should eq 0 }
|
24
64
|
end
|
65
|
+
|
66
|
+
context 'when either earliest_start_time is nil' do
|
67
|
+
let(:earliest_start_time) { nil }
|
68
|
+
its(:total_load_time) { should eq 0 }
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
context 'when noth latest_end_time or earliest_start_time are not empty' do
|
73
|
+
let(:earliest_start_time) { Time.current }
|
74
|
+
let(:latest_end_time) { Time.current + 1.second }
|
75
|
+
|
76
|
+
its(:total_load_time) { should eq (latest_end_time - earliest_start_time) * 1000 }
|
25
77
|
end
|
26
78
|
end
|
27
79
|
|
28
|
-
|
80
|
+
describe '#name' do
|
29
81
|
subject { Speedos::Entries.new([{'pageref' => 'page 1'}, {'pageref' => 'page 1'},]) }
|
30
82
|
|
31
83
|
its(:name) { should eq 'page 1' }
|
data/spec/models/record_spec.rb
CHANGED
@@ -41,7 +41,36 @@ describe Speedos::Record do
|
|
41
41
|
subject.pages
|
42
42
|
end
|
43
43
|
end
|
44
|
+
end
|
45
|
+
|
46
|
+
describe '#refresh_information' do
|
47
|
+
subject { Speedos::Record.create }
|
48
|
+
|
49
|
+
let(:page) { double(name: 'name', earliest_start_time: Time.current, latest_end_time: Time.current, total_load_time: 0) }
|
50
|
+
let(:pages) { [page] }
|
51
|
+
|
52
|
+
before do
|
53
|
+
subject.stub(:pages).and_return(pages)
|
54
|
+
end
|
44
55
|
|
56
|
+
it 'populates pages information' do
|
57
|
+
subject.refresh_information
|
58
|
+
info = subject.information
|
59
|
+
info.size.should eq 1
|
60
|
+
info.first.page_name.should eq page.name
|
61
|
+
info.first.began_at.should eq page.earliest_start_time
|
62
|
+
info.first.finished_at.should eq page.latest_end_time
|
63
|
+
info.first.total_duration.should eq page.total_load_time
|
64
|
+
end
|
65
|
+
|
66
|
+
context 'when there is already information for the record' do
|
67
|
+
before { @info = subject.information.create }
|
68
|
+
|
69
|
+
it 'clears all existing records' do
|
70
|
+
subject.refresh_information
|
71
|
+
subject.information.should_not include @info
|
72
|
+
end
|
73
|
+
end
|
45
74
|
end
|
46
75
|
|
47
76
|
end
|
data/spec/spec_helper.rb
CHANGED
@@ -27,8 +27,11 @@ RSpec.configure do |config|
|
|
27
27
|
|
28
28
|
DatabaseCleaner[:mongoid].strategy = :truncation
|
29
29
|
|
30
|
-
config.before
|
31
|
-
|
30
|
+
config.before(:each) do
|
31
|
+
DatabaseCleaner.start
|
32
|
+
end
|
33
|
+
|
34
|
+
config.after(:each) do
|
32
35
|
DatabaseCleaner.clean
|
33
36
|
end
|
34
37
|
end
|
data/speedos.gemspec
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: speedos
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.12
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- SimplyBusiness
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2013-10-
|
11
|
+
date: 2013-10-04 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: mongoid
|
@@ -131,6 +131,7 @@ executables:
|
|
131
131
|
extensions: []
|
132
132
|
extra_rdoc_files: []
|
133
133
|
files:
|
134
|
+
- .rspec
|
134
135
|
- Gemfile
|
135
136
|
- Gemfile.lock
|
136
137
|
- LICENSE.txt
|
@@ -202,6 +203,7 @@ files:
|
|
202
203
|
- lib/speedos/configuration.rb
|
203
204
|
- lib/speedos/log.rb
|
204
205
|
- lib/speedos/models/entries.rb
|
206
|
+
- lib/speedos/models/information.rb
|
205
207
|
- lib/speedos/models/record.rb
|
206
208
|
- lib/speedos/page.rb
|
207
209
|
- lib/speedos/performance.rb
|