overrides_tracker 0.1.9 → 0.1.13

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.
@@ -0,0 +1,252 @@
1
+ #--
2
+ # Copyright (C)2009 Tony Arcieri
3
+ # You can redistribute this under the terms of the MIT license
4
+ # See file LICENSE for details
5
+ #++
6
+
7
+ module RequireAll
8
+ LoadError = Class.new(::LoadError)
9
+
10
+ # A wonderfully simple way to load your code.
11
+ #
12
+ # The easiest way to use require_all is to just point it at a directory
13
+ # containing a bunch of .rb files. These files can be nested under
14
+ # subdirectories as well:
15
+ #
16
+ # require_all 'lib'
17
+ #
18
+ # This will find all the .rb files under the lib directory and load them.
19
+ #
20
+ # If a file required by require_all references a constant that is not yet
21
+ # loaded, a RequireAll::LoadError will be thrown.
22
+ #
23
+ # You can also give it a glob, which will enumerate all the matching files:
24
+ #
25
+ # require_all 'lib/**/*.rb'
26
+ #
27
+ # It will also accept an array of files:
28
+ #
29
+ # require_all Dir.glob("blah/**/*.rb").reject { |f| stupid_file(f) }
30
+ #
31
+ # Or if you want, just list the files directly as arguments:
32
+ #
33
+ # require_all 'lib/a.rb', 'lib/b.rb', 'lib/c.rb', 'lib/d.rb'
34
+ #
35
+ def require_all(*args)
36
+ # Handle passing an array as an argument
37
+ args.flatten!
38
+
39
+ options = {method: :require}
40
+ options.merge!(args.pop) if args.last.is_a?(Hash)
41
+
42
+ if args.empty?
43
+ puts "no files were loaded due to an empty Array" if $DEBUG
44
+ return false
45
+ end
46
+
47
+ if args.size > 1
48
+ # Expand files below directories
49
+ files = args.map do |path|
50
+ if File.directory? path
51
+ Dir[File.join(path, '**', '*.rb')]
52
+ else
53
+ path
54
+ end
55
+ end.flatten
56
+ else
57
+ arg = args.first
58
+ begin
59
+ # Try assuming we're doing plain ol' require compat
60
+ stat = File.stat(arg)
61
+
62
+ if stat.file?
63
+ files = [arg]
64
+ elsif stat.directory?
65
+ files = Dir.glob File.join(arg, '**', '*.rb')
66
+ else
67
+ raise ArgumentError, "#{arg} isn't a file or directory"
68
+ end
69
+ rescue SystemCallError
70
+ # If the stat failed, maybe we have a glob!
71
+ files = Dir.glob arg
72
+
73
+ # Maybe it's an .rb file and the .rb was omitted
74
+ if File.file?(arg + '.rb')
75
+ file = arg + '.rb'
76
+ options[:method] != :autoload ? __require(options[:method], file) : __autoload(file, file, options)
77
+ return true
78
+ end
79
+
80
+ # If we ain't got no files, the glob failed
81
+ #raise LoadError, "no such file to load -- #{arg}" if files.empty?
82
+ end
83
+ end
84
+
85
+ return if files.empty?
86
+
87
+ if options[:method] == :autoload
88
+ files.map! { |file_| [file_, File.expand_path(file_)] }
89
+ files.each do |file_, full_path|
90
+ __autoload(file_, full_path, options)
91
+ end
92
+
93
+ return true
94
+ end
95
+
96
+ files.map { |file_| File.expand_path file_ }.sort.each do |file_|
97
+ begin
98
+ __require(options[:method], file_)
99
+ rescue NameError => e
100
+ # Only wrap NameError exceptions for uninitialized constants
101
+ #raise e unless e.instance_of?(NameError) && e.message.include?('uninitialized constant')
102
+ #raise LoadError, "Could not require #{file_} (#{e}). Please require the necessary files"
103
+ end
104
+ end
105
+
106
+ true
107
+ end
108
+
109
+ # Works like require_all, but paths are relative to the caller rather than
110
+ # the current working directory
111
+ def require_rel(*paths)
112
+ # Handle passing an array as an argument
113
+ paths.flatten!
114
+ return false if paths.empty?
115
+
116
+ source_directory = File.dirname caller.first.sub(/:\d+$/, '')
117
+ paths.each do |path|
118
+ require_all File.join(source_directory, path)
119
+ end
120
+ end
121
+
122
+ # Loads all files like require_all instead of requiring
123
+ def load_all(*paths)
124
+ require_all paths, method: :load
125
+ end
126
+
127
+ # Loads all files by using relative paths of the caller rather than
128
+ # the current working directory
129
+ def load_rel(*paths)
130
+ paths.flatten!
131
+ return false if paths.empty?
132
+
133
+ source_directory = File.dirname caller.first.sub(/:\d+$/, '')
134
+ paths.each do |path|
135
+ require_all File.join(source_directory, path), method: :load
136
+ end
137
+ end
138
+
139
+ # Performs Kernel#autoload on all of the files rather than requiring immediately.
140
+ #
141
+ # Note that all Ruby files inside of the specified directories should have same module name as
142
+ # the directory itself and file names should reflect the class/module names.
143
+ # For example if there is a my_file.rb in directories dir1/dir2/ then
144
+ # there should be a declaration like this in my_file.rb:
145
+ # module Dir1
146
+ # module Dir2
147
+ # class MyFile
148
+ # ...
149
+ # end
150
+ # end
151
+ # end
152
+ #
153
+ # If the filename and namespaces won't match then my_file.rb will be loaded into wrong module!
154
+ # Better to fix these files.
155
+ #
156
+ # Set $DEBUG=true to see how files will be autoloaded if experiencing any problems.
157
+ #
158
+ # If trying to perform autoload on some individual file or some inner module, then you'd have
159
+ # to always specify *:base_dir* option to specify where top-level namespace resides.
160
+ # Otherwise it's impossible to know the namespace of the loaded files.
161
+ #
162
+ # For example loading only my_file.rb from dir1/dir2 with autoload_all:
163
+ #
164
+ # autoload_all File.dirname(__FILE__) + '/dir1/dir2/my_file',
165
+ # base_dir: File.dirname(__FILE__) + '/dir1'
166
+ #
167
+ # WARNING: All modules will be created even if files themselves aren't loaded yet, meaning
168
+ # that all the code which depends of the modules being loaded or not will not work, like usages
169
+ # of define? and it's friends.
170
+ #
171
+ # Also, normal caveats of using Kernel#autoload apply - you have to remember that before
172
+ # applying any monkey-patches to code using autoload, you'll have to reference the full constant
173
+ # to load the code before applying your patch!
174
+
175
+ def autoload_all(*paths)
176
+ paths.flatten!
177
+ return false if paths.empty?
178
+ require "pathname"
179
+
180
+ options = {method: :autoload}
181
+ options.merge!(paths.pop) if paths.last.is_a?(Hash)
182
+
183
+ paths.each do |path|
184
+ require_all path, {base_dir: path}.merge(options)
185
+ end
186
+ end
187
+
188
+ # Performs autoloading relatively from the caller instead of using current working directory
189
+ def autoload_rel(*paths)
190
+ paths.flatten!
191
+ return false if paths.empty?
192
+ require "pathname"
193
+
194
+ options = {method: :autoload}
195
+ options.merge!(paths.pop) if paths.last.is_a?(Hash)
196
+
197
+ source_directory = File.dirname caller.first.sub(/:\d+$/, '')
198
+ paths.each do |path|
199
+ file_path = Pathname.new(source_directory).join(path).to_s
200
+ require_all file_path, {method: :autoload,
201
+ base_dir: source_directory}.merge(options)
202
+ end
203
+ end
204
+
205
+ private
206
+
207
+ def __require(method, file)
208
+ Kernel.send(method, file)
209
+ end
210
+
211
+ def __autoload(file, full_path, options)
212
+ last_module = "Object" # default constant where namespaces are created into
213
+ begin
214
+ base_dir = Pathname.new(options[:base_dir]).realpath
215
+ rescue Errno::ENOENT
216
+ raise LoadError, ":base_dir doesn't exist at #{options[:base_dir]}"
217
+ end
218
+ Pathname.new(file).realpath.descend do |entry|
219
+ # skip until *entry* is same as desired directory
220
+ # or anything inside of it avoiding to create modules
221
+ # from the top-level directories
222
+ next if (entry <=> base_dir) < 0
223
+
224
+ # get the module into which a new module is created or
225
+ # autoload performed
226
+ mod = Object.class_eval(last_module)
227
+
228
+ without_ext = entry.basename(entry.extname).to_s
229
+
230
+ const =
231
+ if defined? ActiveSupport::Inflector
232
+ ActiveSupport::Inflector.camelize(without_ext)
233
+ else
234
+ without_ext.split("_").map {|word| word.capitalize}.join
235
+ end
236
+
237
+ if entry.file? || (entry.directory? && entry.sub_ext('.rb').file?)
238
+ mod.class_eval do
239
+ puts "autoloading #{mod}::#{const} from #{full_path}" if $DEBUG
240
+ autoload const, full_path
241
+ end
242
+ else
243
+ mod.class_eval "module #{const} end" if entry.directory?
244
+ end
245
+
246
+ last_module += "::#{const}" if entry.directory?
247
+ end
248
+ end
249
+
250
+ end
251
+
252
+ include RequireAll
@@ -1,50 +1,78 @@
1
1
  require 'json'
2
2
  require 'net/https'
3
+ require 'digest'
3
4
 
4
5
  class OverridesTracker::Api
5
-
6
- API_HOST = ENV['OVERRIDES_TRACKER_DEVELOPMENT'] ? "localhost:3000" : "overrides.io"
7
- API_PROTOCOL = ENV['OVERRIDES_TRACKER_DEVELOPMENT'] ? "http" : "https"
6
+ API_HOST = ENV['OVERRIDES_TRACKER_DEVELOPMENT'] ? 'localhost:3000' : 'www.overrides.io'
7
+ API_PROTOCOL = ENV['OVERRIDES_TRACKER_DEVELOPMENT'] ? 'http' : 'https'
8
8
  API_DOMAIN = "#{API_PROTOCOL}://#{API_HOST}"
9
9
 
10
10
  API_BASE = "#{API_DOMAIN}/api/v1"
11
11
 
12
12
  def self.report_build(api_token, branch_name, last_commit_id, last_commit_name, file_path)
13
-
14
13
  disable_net_blockers!
15
14
 
16
- uri = URI(API_DOMAIN)
17
- client = build_client(uri)
18
-
19
- request = Net::HTTP::Post.new('/api/v1/builds')
20
- form_data = [['api_token',api_token], ['branch_name', branch_name],['build_provider_id', last_commit_id], ['build_name', last_commit_name], ['result_file', File.open(file_path)]]
21
- request.set_form form_data, 'multipart/form-data'
22
-
23
15
  puts ' '
24
16
  puts '==========='
25
17
  puts 'Sending report to Overrides.io...'
26
18
 
19
+ file_hash = Digest::SHA256.hexdigest(File.read(file_path))
20
+
21
+ if find_or_report_build(api_token, branch_name, last_commit_id, last_commit_name, file_hash)
22
+ puts 'Success.'.green
23
+ true
24
+ else
25
+ file = File.open(file_path)
26
+ form_data = [['api_token', api_token], ['branch_name', branch_name], ['build_provider_id', last_commit_id],
27
+ ['build_name', last_commit_name], ['result_file', file], ['file_hash', file_hash]]
28
+
29
+ uri = URI(API_DOMAIN)
30
+ client = build_client(uri)
31
+ request = Net::HTTP::Post.new('/api/v1/builds')
32
+ request.set_form form_data, 'multipart/form-data'
33
+
34
+ begin
35
+ response = client.request(request)
36
+ puts 'Success.'.green
37
+ true
38
+ rescue SocketError => e
39
+ puts 'Failed to report to the Overrides API.'.red
40
+ false
41
+ end
42
+ end
43
+ end
44
+
45
+ def self.find_or_report_build(api_token, branch_name, last_commit_id, last_commit_name, file_hash)
46
+ uri = URI(API_DOMAIN)
47
+ client = build_client(uri)
48
+
49
+ form_data = [['api_token', api_token], ['branch_name', branch_name], ['build_provider_id', last_commit_id],
50
+ ['build_name', last_commit_name], ['file_hash', file_hash]]
51
+
52
+ request = Net::HTTP::Post.new('/api/v1/builds/find_or_create')
53
+ request.set_form form_data
54
+
27
55
  begin
28
56
  response = client.request(request)
29
- response_hash = JSON.load(response.body.to_str)
30
- puts 'Success.'.green
31
- rescue SocketError => each
57
+ if response.code == '404'
58
+ false
59
+ else
60
+ true
61
+ end
62
+ rescue SocketError => e
32
63
  puts 'Failed to report to the Overrides API.'.red
64
+ false
33
65
  end
34
66
  end
35
-
36
-
67
+
37
68
  def self.build_client(uri)
38
69
  client = Net::HTTP.new(uri.host, uri.port)
39
70
  client.use_ssl = true if uri.port == 443
40
71
  client.verify_mode = OpenSSL::SSL::VERIFY_NONE
41
72
 
42
-
43
73
  client
44
74
  end
45
75
 
46
- private
47
-
48
76
  def self.disable_net_blockers!
49
77
  begin
50
78
  require 'webmock'