pjhyett / github-gem-builder

The scripts used to build RubyGems on GitHub

This URL has Read+Write access

github-gem-builder / gem_eval_test.rb
100644 243 lines (213 sloc) 5.118 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
require 'test/unit'
require 'net/http'
require 'cgi'
 
OUTPUT = !!ENV['SERVER_OUTPUT']
puts "gem_eval server output disabled, set SERVER_OUTPUT=1 to enable" if ! OUTPUT
 
class GemEvalTest < Test::Unit::TestCase
  def setup
    system("mv git_mock git")
    @pid = fork { exec("PATH=.:$PATH ruby gem_eval.rb #{' > /dev/null 2>&1' unless OUTPUT}") }
 
    # wait for server to start
    Timeout::timeout(5) do
      begin
        TCPSocket.open('localhost', 4567) {}
        server_started = true
      rescue Errno::ECONNREFUSED
        server_started = false
        sleep 0.1
        retry
      end until server_started
    end
  end
 
  def teardown
    system("pkill -f 'ruby gem_eval.rb'")
    system("mv git git_mock")
  end
 
  def test_access_to_untainted_locals
    %w(repo data spec params).each do |v|
      assert_nil_error v
    end
  end
 
  def test_timeout
    puts "\ntesting timeout..."
    begin
      timeout(7) do
        s = req <<-EOS
def forever
loop{}
ensure
forever
end
forever
EOS
        assert_equal "ERROR: execution expired", s
      end
    rescue Timeout::Error
      fail "timed out! no good!"
    end
  end
 
  def test_legit_gemspec_works
    gemspec = <<-EOS
Gem::Specification.new do |s|
s.name = "name"
s.description = 'description'
s.version = "0.0.9"
s.summary = ""
s.authors = ["coderrr"]
s.files = ['x']
end
EOS
    expected_response = <<-EOS
--- !ruby/object:Gem::Specification
name: name
version: !ruby/object:Gem::Version
version: 0.0.9
platform: ruby
authors:
- coderrr
autorequire:
bindir: bin
cert_chain: []
 
date: 2008-10-31 00:00:00 +07:00
default_executable:
dependencies: []
 
description: description
email:
executables: []
 
extensions: []
 
extra_rdoc_files: []
 
files:
- x
has_rdoc: false
homepage:
post_install_message:
rdoc_options: []
 
require_paths:
- lib
required_ruby_version: !ruby/object:Gem::Requirement
requirements:
- - ">="
- !ruby/object:Gem::Version
version: "0"
version:
required_rubygems_version: !ruby/object:Gem::Requirement
requirements:
- - ">="
- !ruby/object:Gem::Version
version: "0"
version:
requirements: []
 
rubyforge_project:
rubygems_version: 1.3.0
signing_key:
specification_version: 2
summary: ""
test_files: []
EOS
    assert_equal clean_yaml(expected_response), clean_yaml(req(gemspec))
  end
 
  def test_gemspec_with_glob_works
    system("mkdir globdir && cd globdir && touch a.rb b.rb c.txt")
    gemspec = <<-EOS
Gem::Specification.new do |s|
s.name = "name"
s.description = 'description'
s.version = "0.0.9"
s.summary = ""
s.authors = ["coderrr"]
s.files = Dir.glob("globdir/**.rb")
s.test_files = Dir["globdir/**"]
# make sure array globs work with .glob and make sure glob flags work
s.executables = Dir.glob(["globdir/*.TXT", "globdir/*.RB"], File::FNM_CASEFOLD)
# make sure array globs work with [] and make sure we cant access files in parent dirs
s.extra_rdoc_files = Dir["/etc/*", "globdir"]
end
EOS
    expected_response = <<-EOS
--- !ruby/object:Gem::Specification
name: name
version: !ruby/object:Gem::Version
version: 0.0.9
platform: ruby
authors:
- coderrr
autorequire:
bindir: bin
cert_chain: []
 
 
default_executable:
dependencies: []
 
description: description
email:
executables:
- globdir/c.txt
- globdir/a.rb
- globdir/b.rb
extensions: []
 
extra_rdoc_files:
- globdir
files:
- globdir/a.rb
- globdir/b.rb
has_rdoc: false
homepage:
post_install_message:
rdoc_options: []
 
require_paths:
- lib
required_ruby_version: !ruby/object:Gem::Requirement
requirements:
- - ">="
- !ruby/object:Gem::Version
version: "0"
version:
required_rubygems_version: !ruby/object:Gem::Requirement
requirements:
- - ">="
- !ruby/object:Gem::Version
version: "0"
version:
requirements: []
 
rubyforge_project:
 
signing_key:
specification_version: 2
summary: ""
test_files:
- globdir/a.rb
- globdir/b.rb
- globdir/c.txt
EOS
    assert_equal clean_yaml(expected_response), clean_yaml(req(gemspec))
  ensure
    system("rm -rf globdir")
  end
 
  def test_tmpdir_is_destroyed
    Dir.mkdir('tmp/gem_eval_test')
    assert File.exist?('tmp/gem_eval_test')
    req('')
    assert ! File.exist?('tmp/gem_eval_test')
  end
 
  def test_secure_parser_begin
    resp = req <<-EOS
BEGIN {require 'bogus_file'}
EOS
    assert resp.include?('Insecure operation')
  end
 
  def test_secure_parser_end
    resp = req <<-EOS
END {fail 'secret exit'}
EOS
    assert !resp.include?('secret exit')
  end
 
  private
 
  def clean_yaml(y)
    y.strip.sub(/^date:.+$/,'').sub(/^rubygems_version:.+$/,'')
  end
  
  def assert_nil_error(v)
    assert req("#{v}.abc").include?("undefined method `abc' for nil"), "#{v} was not nil"
  end
 
  def req(data)
    Net::HTTP.start 'localhost', 4567 do |h|
      h.post('/', "data=#{CGI.escape data}&repo=gem_eval_test").body
    end
  end
end