mongo 2.19.3 → 2.20.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +37 -1
- data/Rakefile +81 -172
- data/lib/mongo/cluster/topology/base.rb +16 -0
- data/lib/mongo/cluster.rb +27 -1
- data/lib/mongo/collection/view/iterable.rb +1 -0
- data/lib/mongo/collection.rb +4 -2
- data/lib/mongo/config.rb +2 -2
- data/lib/mongo/error/transactions_not_supported.rb +34 -0
- data/lib/mongo/error.rb +1 -0
- data/lib/mongo/grid/fs_bucket.rb +6 -0
- data/lib/mongo/monitoring/event/secure.rb +1 -1
- data/lib/mongo/operation/shared/executable.rb +43 -27
- data/lib/mongo/operation/shared/response_handling.rb +23 -25
- data/lib/mongo/retryable/base_worker.rb +28 -3
- data/lib/mongo/retryable/read_worker.rb +16 -14
- data/lib/mongo/retryable/write_worker.rb +11 -8
- data/lib/mongo/retryable.rb +2 -2
- data/lib/mongo/server/app_metadata/environment.rb +64 -9
- data/lib/mongo/server/app_metadata.rb +5 -4
- data/lib/mongo/server/description/features.rb +1 -0
- data/lib/mongo/server/pending_connection.rb +19 -6
- data/lib/mongo/server_selector/base.rb +32 -6
- data/lib/mongo/session/server_session/dirtyable.rb +52 -0
- data/lib/mongo/session/server_session.rb +3 -0
- data/lib/mongo/session/session_pool.rb +12 -18
- data/lib/mongo/session.rb +32 -0
- data/lib/mongo/socket/ssl.rb +22 -1
- data/lib/mongo/uri.rb +0 -4
- data/lib/mongo/version.rb +1 -5
- data/mongo.gemspec +9 -18
- data/spec/atlas/atlas_connectivity_spec.rb +4 -4
- data/spec/faas/ruby-sam-app/Gemfile +9 -0
- data/spec/faas/ruby-sam-app/mongodb/Gemfile +4 -0
- data/spec/faas/ruby-sam-app/mongodb/app.rb +149 -0
- data/spec/faas/ruby-sam-app/template.yaml +48 -0
- data/spec/integration/client_side_encryption/corpus_spec.rb +10 -2
- data/spec/integration/client_side_encryption/range_explicit_encryption_prose_spec.rb +3 -0
- data/spec/integration/retryable_reads_errors_spec.rb +196 -31
- data/spec/integration/retryable_writes_errors_spec.rb +156 -0
- data/spec/integration/sdam_error_handling_spec.rb +2 -0
- data/spec/lite_spec_helper.rb +0 -10
- data/spec/mongo/cluster_spec.rb +36 -0
- data/spec/mongo/collection/view/aggregation_spec.rb +6 -1
- data/spec/mongo/collection/view/explainable_spec.rb +2 -0
- data/spec/mongo/collection_crud_spec.rb +2 -1
- data/spec/mongo/operation/insert_spec.rb +1 -1
- data/spec/mongo/retryable/write_worker_spec.rb +39 -0
- data/spec/mongo/server/app_metadata/environment_spec.rb +135 -0
- data/spec/mongo/server/app_metadata_spec.rb +12 -2
- data/spec/mongo/server/connection_spec.rb +26 -0
- data/spec/mongo/session/session_pool_spec.rb +1 -16
- data/spec/mongo/session_transaction_spec.rb +15 -0
- data/spec/mongo/uri_spec.rb +0 -9
- data/spec/runners/crud/test.rb +0 -8
- data/spec/runners/crud.rb +1 -1
- data/spec/runners/transactions/test.rb +12 -3
- data/spec/runners/unified/assertions.rb +16 -3
- data/spec/runners/unified/crud_operations.rb +12 -0
- data/spec/runners/unified/support_operations.rb +3 -5
- data/spec/runners/unified/test.rb +8 -1
- data/spec/spec_tests/data/client_side_encryption/explain.yml +2 -2
- data/spec/spec_tests/data/client_side_encryption/fle2v2-BypassQueryAnalysis.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Compact.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-CreateCollection.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-DecryptExistingData.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Delete.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-EncryptedFields-vs-EncryptedFieldsMap.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-EncryptedFields-vs-jsonSchema.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-EncryptedFieldsMap-defaults.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-FindOneAndUpdate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-InsertFind-Indexed.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-InsertFind-Unindexed.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-MissingKey.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-NoEncryption.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-Aggregate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-Correctness.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-Delete.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-FindOneAndUpdate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-InsertFind.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Date-Update.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-Aggregate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-Correctness.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-Delete.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-FindOneAndUpdate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-InsertFind.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Decimal-Update.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-Aggregate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-Correctness.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-Delete.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-FindOneAndUpdate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-InsertFind.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DecimalPrecision-Update.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-Aggregate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-Correctness.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-Delete.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-FindOneAndUpdate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-InsertFind.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Double-Update.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-Aggregate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-Correctness.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-Delete.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-FindOneAndUpdate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-InsertFind.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-DoublePrecision-Update.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-Aggregate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-Correctness.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-Delete.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-FindOneAndUpdate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-InsertFind.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Int-Update.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-Aggregate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-Correctness.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-Delete.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-FindOneAndUpdate.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-InsertFind.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-Long-Update.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Range-WrongType.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-Update.yml +1 -0
- data/spec/spec_tests/data/client_side_encryption/fle2v2-validatorAndPartialFieldExpression.yml +2 -1
- data/spec/spec_tests/data/connection_string/invalid-uris.yml +0 -10
- data/spec/spec_tests/data/connection_string/valid-options.yml +13 -0
- data/spec/spec_tests/data/crud_unified/aggregate-write-readPreference.yml +2 -0
- data/spec/spec_tests/data/crud_unified/db-aggregate-write-readPreference.yml +2 -0
- data/spec/spec_tests/data/crud_unified/find-test-all-options.yml +348 -0
- data/spec/spec_tests/data/index_management/createSearchIndex.yml +5 -3
- data/spec/spec_tests/data/index_management/createSearchIndexes.yml +7 -4
- data/spec/spec_tests/data/index_management/dropSearchIndex.yml +2 -1
- data/spec/spec_tests/data/index_management/listSearchIndexes.yml +13 -7
- data/spec/spec_tests/data/index_management/updateSearchIndex.yml +2 -1
- data/spec/spec_tests/data/retryable_writes/unified/bulkWrite-serverErrors.yml +3 -6
- data/spec/spec_tests/data/retryable_writes/unified/insertOne-serverErrors.yml +3 -6
- data/spec/spec_tests/data/run_command_unified/runCommand.yml +319 -0
- data/spec/spec_tests/data/sessions_unified/driver-sessions-dirty-session-errors.yml +351 -0
- data/spec/spec_tests/data/unified/valid-pass/poc-crud.yml +1 -1
- data/spec/spec_tests/data/unified/valid-pass/poc-retryable-writes.yml +7 -7
- data/spec/spec_tests/data/unified/valid-pass/poc-sessions.yml +3 -4
- data/spec/spec_tests/data/unified/valid-pass/poc-transactions-convenient-api.yml +1 -1
- data/spec/spec_tests/data/unified/valid-pass/poc-transactions-mongos-pin-auto.yml +1 -1
- data/spec/spec_tests/data/unified/valid-pass/poc-transactions.yml +3 -3
- data/spec/spec_tests/run_command_unified_spec.rb +13 -0
- data/spec/spec_tests/sdam_unified_spec.rb +2 -0
- data/spec/spec_tests/transactions_unified_spec.rb +2 -1
- data/spec/support/certificates/atlas-ocsp-ca.crt +89 -77
- data/spec/support/certificates/atlas-ocsp.crt +117 -122
- data/spec/support/certificates/retrieve-atlas-cert +1 -1
- data/spec/support/constraints.rb +6 -0
- data/spec/support/ocsp +1 -1
- data/spec/support/recording_logger.rb +27 -0
- metadata +1245 -1298
- checksums.yaml.gz.sig +0 -0
- data/spec/shared/LICENSE +0 -20
- data/spec/shared/bin/get-mongodb-download-url +0 -17
- data/spec/shared/bin/s3-copy +0 -45
- data/spec/shared/bin/s3-upload +0 -69
- data/spec/shared/lib/mrss/child_process_helper.rb +0 -80
- data/spec/shared/lib/mrss/cluster_config.rb +0 -231
- data/spec/shared/lib/mrss/constraints.rb +0 -378
- data/spec/shared/lib/mrss/docker_runner.rb +0 -295
- data/spec/shared/lib/mrss/eg_config_utils.rb +0 -51
- data/spec/shared/lib/mrss/event_subscriber.rb +0 -210
- data/spec/shared/lib/mrss/lite_constraints.rb +0 -238
- data/spec/shared/lib/mrss/server_version_registry.rb +0 -113
- data/spec/shared/lib/mrss/session_registry.rb +0 -69
- data/spec/shared/lib/mrss/session_registry_legacy.rb +0 -60
- data/spec/shared/lib/mrss/spec_organizer.rb +0 -179
- data/spec/shared/lib/mrss/utils.rb +0 -37
- data/spec/shared/share/Dockerfile.erb +0 -330
- data/spec/shared/share/haproxy-1.conf +0 -16
- data/spec/shared/share/haproxy-2.conf +0 -17
- data/spec/shared/shlib/config.sh +0 -27
- data/spec/shared/shlib/distro.sh +0 -74
- data/spec/shared/shlib/server.sh +0 -416
- data/spec/shared/shlib/set_env.sh +0 -169
- data/spec/spec_tests/data/cmap/pool-clear-interrupt-immediately.yml +0 -49
- data/spec/support/faas/app/aws_lambda/mongodb/Gemfile.lock +0 -19
- data.tar.gz.sig +0 -3
- metadata.gz.sig +0 -0
@@ -1,60 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
# encoding: utf-8
|
3
|
-
|
4
|
-
require 'singleton'
|
5
|
-
|
6
|
-
module Mrss
|
7
|
-
|
8
|
-
def self.patch_mongo_for_session_registry
|
9
|
-
|
10
|
-
Mongo::Client.class_eval do
|
11
|
-
alias :get_session_without_tracking :get_session
|
12
|
-
|
13
|
-
def get_session(options = {})
|
14
|
-
get_session_without_tracking(options).tap do |session|
|
15
|
-
SessionRegistry.instance.register(session)
|
16
|
-
end
|
17
|
-
end
|
18
|
-
end
|
19
|
-
|
20
|
-
Mongo::Session.class_eval do
|
21
|
-
alias :end_session_without_tracking :end_session
|
22
|
-
|
23
|
-
def end_session
|
24
|
-
SessionRegistry.instance.unregister(self)
|
25
|
-
end_session_without_tracking
|
26
|
-
end
|
27
|
-
end
|
28
|
-
end
|
29
|
-
end
|
30
|
-
|
31
|
-
module Mrss
|
32
|
-
class SessionRegistry
|
33
|
-
include Singleton
|
34
|
-
|
35
|
-
def initialize
|
36
|
-
@registry = {}
|
37
|
-
end
|
38
|
-
|
39
|
-
def register(session)
|
40
|
-
@registry[session.session_id] = session if session
|
41
|
-
end
|
42
|
-
|
43
|
-
def unregister(session)
|
44
|
-
@registry.delete(session.session_id) unless session.ended?
|
45
|
-
end
|
46
|
-
|
47
|
-
def verify_sessions_ended!
|
48
|
-
@registry.delete_if { |_, session| session.ended? }
|
49
|
-
|
50
|
-
unless @registry.empty?
|
51
|
-
sessions = @registry.map { |_, session| session }
|
52
|
-
raise "Session registry contains live sessions: #{sessions.join(', ')}"
|
53
|
-
end
|
54
|
-
end
|
55
|
-
|
56
|
-
def clear_registry
|
57
|
-
@registry = {}
|
58
|
-
end
|
59
|
-
end
|
60
|
-
end
|
@@ -1,179 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
# encoding: utf-8
|
3
|
-
|
4
|
-
autoload :JSON, 'json'
|
5
|
-
autoload :FileUtils, 'fileutils'
|
6
|
-
autoload :Find, 'find'
|
7
|
-
|
8
|
-
module Mrss
|
9
|
-
|
10
|
-
autoload :ChildProcessHelper, 'mrss/child_process_helper'
|
11
|
-
|
12
|
-
# Organizes and runs all of the tests in the test suite in batches.
|
13
|
-
#
|
14
|
-
# Organizing the tests in batches serves two purposes:
|
15
|
-
#
|
16
|
-
# 1. This allows running unit tests before integration tests, therefore
|
17
|
-
# in theory revealing failures quicker on average.
|
18
|
-
# 2. This allows running some tests that have high intermittent failure rate
|
19
|
-
# in their own test process.
|
20
|
-
#
|
21
|
-
# This class aggregates RSpec results after the test runs.
|
22
|
-
class SpecOrganizer
|
23
|
-
|
24
|
-
class BucketsNotPrioritized < StandardError
|
25
|
-
end
|
26
|
-
|
27
|
-
def initialize(root: nil, classifiers:, priority_order:,
|
28
|
-
spec_root: nil, rspec_json_path: nil, rspec_all_json_path: nil,
|
29
|
-
randomize: false
|
30
|
-
)
|
31
|
-
@spec_root = spec_root || File.join(root, 'spec')
|
32
|
-
@classifiers = classifiers
|
33
|
-
@priority_order = priority_order
|
34
|
-
@rspec_json_path = rspec_json_path || File.join(root, 'tmp/rspec.json')
|
35
|
-
@rspec_all_json_path = rspec_all_json_path || File.join(root, 'tmp/rspec-all.json')
|
36
|
-
@randomize = !!randomize
|
37
|
-
end
|
38
|
-
|
39
|
-
attr_reader :spec_root, :classifiers, :priority_order
|
40
|
-
attr_reader :rspec_json_path, :rspec_all_json_path
|
41
|
-
|
42
|
-
def randomize?
|
43
|
-
@randomize
|
44
|
-
end
|
45
|
-
|
46
|
-
def seed
|
47
|
-
@seed ||= (rand * 100_000).to_i
|
48
|
-
end
|
49
|
-
|
50
|
-
def buckets
|
51
|
-
@buckets ||= {}.tap do |buckets|
|
52
|
-
Find.find(spec_root) do |path|
|
53
|
-
next unless File.file?(path)
|
54
|
-
next unless path =~ /_spec\.rb\z/
|
55
|
-
rel_path = path[(spec_root.length + 1)..path.length]
|
56
|
-
|
57
|
-
found = false
|
58
|
-
classifiers.each do |(regexp, category)|
|
59
|
-
if regexp =~ rel_path
|
60
|
-
buckets[category] ||= []
|
61
|
-
buckets[category] << File.join('spec', rel_path)
|
62
|
-
found = true
|
63
|
-
break
|
64
|
-
end
|
65
|
-
end
|
66
|
-
|
67
|
-
unless found
|
68
|
-
buckets[nil] ||= []
|
69
|
-
buckets[nil] << File.join('spec', rel_path)
|
70
|
-
end
|
71
|
-
end
|
72
|
-
end.freeze
|
73
|
-
end
|
74
|
-
|
75
|
-
def ordered_buckets
|
76
|
-
@ordered_buckets ||= {}.tap do |ordered_buckets|
|
77
|
-
buckets = self.buckets.dup
|
78
|
-
priority_order.each do |category|
|
79
|
-
files = buckets.delete(category)
|
80
|
-
ordered_buckets[category] = files
|
81
|
-
end
|
82
|
-
|
83
|
-
if files = buckets.delete(nil)
|
84
|
-
ordered_buckets[nil] = files
|
85
|
-
end
|
86
|
-
|
87
|
-
unless buckets.empty?
|
88
|
-
raise BucketsNotPrioritized, "Some buckets were not prioritized: #{buckets.keys.map(&:to_s).join(', ')}"
|
89
|
-
end
|
90
|
-
end.freeze
|
91
|
-
end
|
92
|
-
|
93
|
-
def run
|
94
|
-
run_buckets(*buckets.keys)
|
95
|
-
end
|
96
|
-
|
97
|
-
def run_buckets(*buckets)
|
98
|
-
FileUtils.rm_f(rspec_all_json_path)
|
99
|
-
|
100
|
-
buckets.each do |bucket|
|
101
|
-
if bucket && !self.buckets[bucket]
|
102
|
-
raise "Unknown bucket #{bucket}"
|
103
|
-
end
|
104
|
-
end
|
105
|
-
buckets = Hash[self.buckets.select { |k, v| buckets.include?(k) }]
|
106
|
-
|
107
|
-
failed = []
|
108
|
-
|
109
|
-
priority_order.each do |category|
|
110
|
-
if files = buckets.delete(category)
|
111
|
-
unless run_files(category, files)
|
112
|
-
failed << category
|
113
|
-
end
|
114
|
-
end
|
115
|
-
end
|
116
|
-
if files = buckets.delete(nil)
|
117
|
-
unless run_files('remaining', files)
|
118
|
-
failed << 'remaining'
|
119
|
-
end
|
120
|
-
end
|
121
|
-
|
122
|
-
unless buckets.empty?
|
123
|
-
raise "Some buckets were not executed: #{buckets.keys.map(&:to_s).join(', ')}"
|
124
|
-
end
|
125
|
-
|
126
|
-
if failed.any?
|
127
|
-
raise "The following buckets failed: #{failed.map(&:to_s).join(', ')}"
|
128
|
-
end
|
129
|
-
end
|
130
|
-
|
131
|
-
def run_files(category, paths)
|
132
|
-
puts "Running #{category.to_s.gsub('_', ' ')} tests"
|
133
|
-
FileUtils.rm_f(rspec_json_path)
|
134
|
-
cmd = %w(rspec) + paths
|
135
|
-
if randomize?
|
136
|
-
cmd += %W(--order rand:#{seed})
|
137
|
-
end
|
138
|
-
|
139
|
-
begin
|
140
|
-
puts "Running #{cmd.join(' ')}"
|
141
|
-
ChildProcessHelper.check_call(cmd)
|
142
|
-
ensure
|
143
|
-
if File.exist?(rspec_json_path)
|
144
|
-
if File.exist?(rspec_all_json_path)
|
145
|
-
merge_rspec_results
|
146
|
-
else
|
147
|
-
FileUtils.cp(rspec_json_path, rspec_all_json_path)
|
148
|
-
end
|
149
|
-
end
|
150
|
-
end
|
151
|
-
|
152
|
-
true
|
153
|
-
rescue ChildProcessHelper::SpawnError
|
154
|
-
false
|
155
|
-
end
|
156
|
-
|
157
|
-
def merge_rspec_results
|
158
|
-
all = JSON.parse(File.read(rspec_all_json_path))
|
159
|
-
new = JSON.parse(File.read(rspec_json_path))
|
160
|
-
all['examples'] += new.delete('examples')
|
161
|
-
new.delete('summary').each do |k, v|
|
162
|
-
all['summary'][k] += v
|
163
|
-
end
|
164
|
-
new.delete('version')
|
165
|
-
new.delete('summary_line')
|
166
|
-
# The spec organizer runs all buckets with the same seed, hence
|
167
|
-
# we can drop the seed from new results.
|
168
|
-
new.delete('seed')
|
169
|
-
unless new.empty?
|
170
|
-
raise "Unhandled rspec results keys: #{new.keys.join(', ')}"
|
171
|
-
end
|
172
|
-
# We do not merge summary lines, delete them from aggregated results
|
173
|
-
all.delete('summary_line')
|
174
|
-
File.open(rspec_all_json_path, 'w') do |f|
|
175
|
-
f << JSON.dump(all)
|
176
|
-
end
|
177
|
-
end
|
178
|
-
end
|
179
|
-
end
|
@@ -1,37 +0,0 @@
|
|
1
|
-
# frozen_string_literal: true
|
2
|
-
# encoding: utf-8
|
3
|
-
|
4
|
-
module Mrss
|
5
|
-
module Utils
|
6
|
-
extend self
|
7
|
-
|
8
|
-
def print_backtrace(dest=STDERR)
|
9
|
-
raise
|
10
|
-
rescue => e
|
11
|
-
dest.puts e.backtrace.join("\n")
|
12
|
-
end
|
13
|
-
|
14
|
-
# Parses the given version string, accounting for suffix information that
|
15
|
-
# Gem::Version cannot successfully parse.
|
16
|
-
#
|
17
|
-
# @param [ String ] version the version to parse
|
18
|
-
#
|
19
|
-
# @return [ Gem::Version ] the parsed version
|
20
|
-
#
|
21
|
-
# @raise [ ArgumentError ] if the string cannot be parsed.
|
22
|
-
def parse_version(version)
|
23
|
-
Gem::Version.new(version)
|
24
|
-
rescue ArgumentError
|
25
|
-
match = version.match(/\A(?<major>\d+)\.(?<minor>\d+)\.(?<patch>\d+)?(-[A-Za-z\+\d]+)?\z/)
|
26
|
-
raise ArgumentError.new("Malformed version number string #{version}") if match.nil?
|
27
|
-
|
28
|
-
Gem::Version.new(
|
29
|
-
[
|
30
|
-
match[:major],
|
31
|
-
match[:minor],
|
32
|
-
match[:patch]
|
33
|
-
].join('.')
|
34
|
-
)
|
35
|
-
end
|
36
|
-
end
|
37
|
-
end
|
@@ -1,330 +0,0 @@
|
|
1
|
-
# Python toolchain as of this writing is available on rhel62, debian92 and
|
2
|
-
# ubuntu1604.
|
3
|
-
#
|
4
|
-
# To run rhel62 in docker, host system must be configured to emulate syscalls:
|
5
|
-
# https://github.com/CentOS/sig-cloud-instance-images/issues/103
|
6
|
-
|
7
|
-
<%
|
8
|
-
|
9
|
-
python_toolchain_url = "https://s3.amazonaws.com//mciuploads/mongo-python-driver-toolchain/#{distro}/ba92de2700c04ee2d4f82c3ffdfc33105140cb04/mongo_python_driver_toolchain_#{distro.gsub('-', '_')}_ba92de2700c04ee2d4f82c3ffdfc33105140cb04_19_11_14_15_33_33.tar.gz"
|
10
|
-
# server_version = '4.3.3'
|
11
|
-
server_url = "http://downloads.10gen.com/linux/mongodb-linux-x86_64-enterprise-#{distro}-#{server_version}.tgz"
|
12
|
-
server_archive_basename = File.basename(server_url)
|
13
|
-
server_extracted_dir = server_archive_basename.sub(/\.(tar\.gz|tgz)$/, '')
|
14
|
-
|
15
|
-
# When changing, also update the hash in shlib/set_env.sh.
|
16
|
-
TOOLCHAIN_VERSION='e8c60866f54bed7e336a37df3a97d6ae1b971b7d'
|
17
|
-
|
18
|
-
def ruby_toolchain_url(ruby)
|
19
|
-
"http://boxes.10gen.com/build/toolchain-drivers/mongo-ruby-driver/#{TOOLCHAIN_VERSION}/#{distro}/#{ruby}.tar.xz"
|
20
|
-
end
|
21
|
-
|
22
|
-
#ruby_toolchain_url = "https://s3.amazonaws.com//mciuploads/mongo-ruby-toolchain/#{distro}/#{TOOLCHAIN_VERSION}/mongo_ruby_driver_toolchain_#{distro.gsub('-', '_')}_patch_#{TOOLCHAIN_VERSION}_#{toolchain_lower}.tar.gz"
|
23
|
-
|
24
|
-
%>
|
25
|
-
|
26
|
-
FROM <%= base_image %>
|
27
|
-
|
28
|
-
ENV DOCKER=1
|
29
|
-
|
30
|
-
<% if debian? %>
|
31
|
-
|
32
|
-
ENV DEBIAN_FRONTEND=noninteractive
|
33
|
-
|
34
|
-
<% else %>
|
35
|
-
|
36
|
-
RUN echo assumeyes=1 |tee -a /etc/yum.conf
|
37
|
-
|
38
|
-
<% end %>
|
39
|
-
|
40
|
-
<% if ruby_head? %>
|
41
|
-
|
42
|
-
# To use current versions of mlaunch, Python 3.7+ is required.
|
43
|
-
# Many distros ship with older Pythons, therefore we need to install
|
44
|
-
# a newer Python from somewhere. This section installs the Python
|
45
|
-
# toolchain which comes with recent Pythons.
|
46
|
-
|
47
|
-
#RUN curl --retry 3 -fL <%= python_toolchain_url %> -o python-toolchain.tar.gz
|
48
|
-
#RUN tar -xC /opt -zf python-toolchain.tar.gz
|
49
|
-
|
50
|
-
<% end %>
|
51
|
-
|
52
|
-
<% if debian? %>
|
53
|
-
|
54
|
-
# zsh is not required for any scripts but it is a better interactive shell
|
55
|
-
# than bash.
|
56
|
-
# Ruby runtime dependencies: libyaml-0-2
|
57
|
-
# Compiling ruby libraries: gcc make
|
58
|
-
# Compiling python packages: python3-dev
|
59
|
-
# JRuby: openjdk-8-jdk-headless
|
60
|
-
# Server dependencies: libsnmp30 libcurl3/libcurl4
|
61
|
-
# Determining OS we are running on: lsb-release
|
62
|
-
# Load balancer testing: haproxy
|
63
|
-
# Kerberos testing: krb5-user
|
64
|
-
# Local Kerberos server: krb5-kdc krb5-admin-server
|
65
|
-
# Installing mlaunch from git: git
|
66
|
-
# ruby-head archive: bzip2
|
67
|
-
# nio4r on JRuby: libgmp-dev
|
68
|
-
# Snappy compression: libsnappy-dev
|
69
|
-
# nokogiri: zlib1g-dev
|
70
|
-
# Mongoid testing: tzdata shared-mime-info
|
71
|
-
# Mongoid application testing: nodejs (8.x or newer)
|
72
|
-
# Test suite: procps for ps (to kill JRubies)
|
73
|
-
#
|
74
|
-
# We currently use Python 2-compatible version of mtools, which
|
75
|
-
# is installable via pip (which uses Python 2). All of the MongoDB
|
76
|
-
# distros have pip installed (but none as of this writing have pip3)
|
77
|
-
# therefore install python-pip in all configurations here.
|
78
|
-
|
79
|
-
<% packages = %w(
|
80
|
-
procps lsb-release bzip2 curl wget gpg zsh
|
81
|
-
git make gcc libyaml-0-2 libgmp-dev zlib1g-dev libsnappy-dev
|
82
|
-
krb5-user krb5-kdc krb5-admin-server libsasl2-dev libsasl2-modules-gssapi-mit
|
83
|
-
haproxy
|
84
|
-
python3-pip
|
85
|
-
tzdata shared-mime-info software-properties-common
|
86
|
-
) %>
|
87
|
-
|
88
|
-
<% if distro =~ /ubuntu2004/ %>
|
89
|
-
<% packages << 'libsnmp35' %>
|
90
|
-
<% else %>
|
91
|
-
<% packages << 'libsnmp30' %>
|
92
|
-
<% end %>
|
93
|
-
|
94
|
-
<% if distro !~ /ubuntu2004/ %>
|
95
|
-
<% packages << 'python-pip' %>
|
96
|
-
<% end %>
|
97
|
-
|
98
|
-
<% if distro =~ /debian10/ %>
|
99
|
-
<% packages << 'openjdk-11-jdk-headless' %>
|
100
|
-
<% elsif distro =~ /ubuntu1404/ %>
|
101
|
-
# Ubuntu 14.04 only has openjdk 7, this is too old to be useful
|
102
|
-
<% else %>
|
103
|
-
<% packages << 'openjdk-8-jdk-headless' %>
|
104
|
-
<% end %>
|
105
|
-
|
106
|
-
# ubuntu1404, ubuntu1604: libcurl3
|
107
|
-
# ubuntu1804, ubuntu2004, debian10: libcurl4
|
108
|
-
<% if distro =~ /ubuntu1804|ubuntu2004|debian10/ %>
|
109
|
-
<% packages << 'libcurl4' %>
|
110
|
-
<% else %>
|
111
|
-
<% packages << 'libcurl3' %>
|
112
|
-
<% end %>
|
113
|
-
|
114
|
-
<% if distro =~ /ubuntu1804|ubuntu2004/ %>
|
115
|
-
<% packages << 'nodejs' %>
|
116
|
-
<% end %>
|
117
|
-
|
118
|
-
<% if distro =~ /ubuntu2004/ %>
|
119
|
-
<% packages += %w(ruby ruby2.7 bundler) %>
|
120
|
-
<% end %>
|
121
|
-
|
122
|
-
RUN apt-get update && apt-get install -y <%= packages.join(' ') %>
|
123
|
-
|
124
|
-
<% if ubuntu? %>
|
125
|
-
RUN wget -O - https://apt.kitware.com/keys/kitware-archive-latest.asc 2>/dev/null | gpg --dearmor - | tee /usr/share/keyrings/kitware-archive-keyring.gpg >/dev/null
|
126
|
-
RUN echo "deb [signed-by=/usr/share/keyrings/kitware-archive-keyring.gpg] https://apt.kitware.com/ubuntu/ $(lsb_release -cs) main" | tee /etc/apt/sources.list.d/kitware.list >/dev/null
|
127
|
-
<% end %>
|
128
|
-
RUN apt-get update && apt-get install -y cmake
|
129
|
-
|
130
|
-
<% else %>
|
131
|
-
|
132
|
-
<% if distro =~ /rhel6/ %>
|
133
|
-
|
134
|
-
# CentOS 6 is dead - to use it retrieve the packages from vault:
|
135
|
-
# https://stackoverflow.com/questions/53562691/error-cannot-retrieve-repository-metadata-repomd-xml-for-repository-base-pl
|
136
|
-
|
137
|
-
<%
|
138
|
-
|
139
|
-
cfg = <<-CFG
|
140
|
-
[base]
|
141
|
-
name=CentOS-$releasever - Base
|
142
|
-
#mirrorlist=http://mirrorlist.centos.org/?release=$releasever&arch=$basearch&repo=os
|
143
|
-
#baseurl=http://mirror.centos.org/centos/$releasever/os/$basearch/
|
144
|
-
baseurl=http://vault.centos.org/6.10/os/x86_64/
|
145
|
-
gpgcheck=1
|
146
|
-
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
|
147
|
-
CFG
|
148
|
-
|
149
|
-
%>
|
150
|
-
|
151
|
-
RUN printf "<%= cfg.gsub("\n", "\\n") %>" >/etc/yum.repos.d/CentOS-Base.repo
|
152
|
-
|
153
|
-
<% end %>
|
154
|
-
|
155
|
-
# Enterprise server: net-snmp
|
156
|
-
# lsb_release: redhat-lsb-core
|
157
|
-
# our runner scripts: which
|
158
|
-
# Ruby dependency: libyaml
|
159
|
-
# compiling python packages: gcc python-devel
|
160
|
-
# Kerberos tests: krb5-workstation + cyrus-sasl-devel to build the
|
161
|
-
# mongo_kerberos gem + cyrus-sasl-gssapi for authentication to work
|
162
|
-
# Local Kerberos server: krb5-server
|
163
|
-
# JRuby: java-1.8.0-openjdk
|
164
|
-
#
|
165
|
-
# Note: lacking cyrus-sasl-gssapi produces a cryptic message
|
166
|
-
# "SASL(-4): no mechanism available: No worthy mechs found"
|
167
|
-
# https://github.com/farorm/python-ad/issues/10
|
168
|
-
|
169
|
-
RUN yum install -y redhat-lsb-core which git gcc libyaml krb5-server \
|
170
|
-
krb5-workstation cyrus-sasl-devel cyrus-sasl-gssapi java-1.8.0-openjdk \
|
171
|
-
net-snmp python3 cmake
|
172
|
-
|
173
|
-
<% if distro =~ /rhel6/ %>
|
174
|
-
|
175
|
-
# RHEL 6 ships with Python 2.6.
|
176
|
-
|
177
|
-
RUN yum install -y centos-release-scl && \
|
178
|
-
yum install -y python27-python python27-python-devel
|
179
|
-
ENV PATH=/opt/rh/python27/root/usr/bin:$PATH \
|
180
|
-
LD_LIBRARY_PATH=/opt/rh/python27/root/usr/lib64
|
181
|
-
|
182
|
-
<% else %>
|
183
|
-
|
184
|
-
RUN yum install -y python-devel
|
185
|
-
|
186
|
-
<% end %>
|
187
|
-
|
188
|
-
<% end %>
|
189
|
-
|
190
|
-
<% if preload? %>
|
191
|
-
|
192
|
-
<% if distro =~ /debian9|ubuntu1604|ubuntu1804/ %>
|
193
|
-
# Install python 3.7 for mlaunch.
|
194
|
-
RUN curl -fL --retry 3 https://github.com/p-mongodb/deps/raw/main/<%= distro %>-python37.tar.xz | \
|
195
|
-
tar xfJ - -C /opt
|
196
|
-
ENV PATH=/opt/python37/bin:$PATH
|
197
|
-
RUN python3 -V
|
198
|
-
<% end %>
|
199
|
-
|
200
|
-
<% if true || distro =~ /rhel|ubuntu1604/ %>
|
201
|
-
|
202
|
-
# Ubuntu 12.04 ships pip 1.0 which is ancient and does not work.
|
203
|
-
#
|
204
|
-
# Ubuntu 16.04 apparently also ships a pip that does not work:
|
205
|
-
# https://stackoverflow.com/questions/37495375/python-pip-install-throws-typeerror-unsupported-operand-types-for-retry
|
206
|
-
# Potentially this only affects environments with less than ideal
|
207
|
-
# connectivity (or, perhaps, when python package registry is experiencing
|
208
|
-
# availability issues) when pip must retry to install packages.
|
209
|
-
#
|
210
|
-
# rhel apparently does not package pip at all in core repoitories,
|
211
|
-
# therefore install it the manual way.
|
212
|
-
#
|
213
|
-
# https://pip.pypa.io/en/stable/installing/
|
214
|
-
RUN curl --retry 3 -fL https://bootstrap.pypa.io/pip/get-pip.py | python3
|
215
|
-
RUN python3 -m pip install --upgrade pip setuptools wheel
|
216
|
-
|
217
|
-
<% end %>
|
218
|
-
|
219
|
-
# Current virtualenv fails with
|
220
|
-
# https://github.com/pypa/virtualenv/issues/1630
|
221
|
-
<% mtools = 'legacy' %>
|
222
|
-
<% case mtools
|
223
|
-
when 'legacy' %>
|
224
|
-
# dateutil dependency is missing in mtools: https://github.com/rueckstiess/mtools/issues/864
|
225
|
-
RUN python3 -m pip install 'virtualenv<20' 'mtools-legacy[mlaunch]' 'pymongo<4' python-dateutil
|
226
|
-
<% when 'git' %>
|
227
|
-
# dateutil dependency is missing in mtools: https://github.com/rueckstiess/mtools/issues/864
|
228
|
-
RUN python3 -m pip install virtualenv 'pymongo>=4' python-dateutil psutil
|
229
|
-
|
230
|
-
# Install mtools from git because released versions do not work with pymongo 4.0
|
231
|
-
RUN git clone https://github.com/p-mongodb/mtools && \
|
232
|
-
cd mtools && \
|
233
|
-
python3 setup.py install
|
234
|
-
<% else %>
|
235
|
-
# mtools[mlaunch] does not work: https://github.com/rueckstiess/mtools/issues/856
|
236
|
-
# dateutil dependency is missing in mtools: https://github.com/rueckstiess/mtools/issues/864
|
237
|
-
RUN python3 -m pip install virtualenv 'pymongo>=4' python-dateutil psutil mtools
|
238
|
-
<% end %>
|
239
|
-
|
240
|
-
<% if @env.fetch('MONGODB_VERSION') >= '4.4' %>
|
241
|
-
# ubuntu1604 installs MarkupSafe 0.0.0 here instead of 2.0.0+
|
242
|
-
# as specified by dependencies, causing OCSP mock to not work.
|
243
|
-
RUN python3 -mpip install asn1crypto oscrypto flask --upgrade
|
244
|
-
<% end %>
|
245
|
-
|
246
|
-
# FLE is tested against 4.0+ servers.
|
247
|
-
<% if @env.fetch('MONGODB_VERSION') >= '4.0' %>
|
248
|
-
# Requirements in drivers-evergreen-tools:
|
249
|
-
# boto3~=1.19 cryptography~=3.4.8 pykmip~=0.10.0
|
250
|
-
# cryptography does not install due to lacking setuptools_rust
|
251
|
-
# (either that version or anything that isn't part of system packages)
|
252
|
-
RUN python3 -mpip install boto3~=1.19 cryptography pykmip~=0.10.0 'sqlalchemy<2.0.0'
|
253
|
-
<% end %>
|
254
|
-
|
255
|
-
<% unless ruby_head? || system_ruby? %>
|
256
|
-
|
257
|
-
RUN curl --retry 3 -fL <%= ruby_toolchain_url(ruby) %> |tar -xC /opt -Jf -
|
258
|
-
ENV PATH=/opt/rubies/<%= ruby %>/bin:$PATH \
|
259
|
-
USE_OPT_TOOLCHAIN=1
|
260
|
-
#ENV PATH=/opt/rubies/python/3/bin:$PATH
|
261
|
-
|
262
|
-
<% end %>
|
263
|
-
|
264
|
-
<% end %>
|
265
|
-
|
266
|
-
<% if distro =~ /debian|ubuntu/ %>
|
267
|
-
# mkdir was moved from /usr/bin to /bin and MongoDB's distros
|
268
|
-
# apparently keep using the old location.
|
269
|
-
# This definitely affects debian10.
|
270
|
-
# https://stackoverflow.com/questions/64653051/make-usr-bin-mkdir-command-not-found-during-gem-install-nokogiri-in-ubuntu
|
271
|
-
RUN test -f /usr/bin/mkdir || ln -s /bin/mkdir /usr/bin/mkdir
|
272
|
-
<% end %>
|
273
|
-
|
274
|
-
WORKDIR /app
|
275
|
-
|
276
|
-
<% if preload? && !ruby_head? %>
|
277
|
-
|
278
|
-
COPY Gemfile .
|
279
|
-
COPY gemfiles gemfiles
|
280
|
-
COPY *.gemspec .
|
281
|
-
COPY lib/<%= project_lib_subdir %>/version.rb lib/<%= project_lib_subdir %>/version.rb
|
282
|
-
RUN bundle install
|
283
|
-
COPY .evergreen/patch-debuggers .evergreen/patch-debuggers
|
284
|
-
<% if system_ruby? %>
|
285
|
-
# Running under docker with root access
|
286
|
-
RUN .evergreen/patch-debuggers /var/lib/gems
|
287
|
-
<% else %>
|
288
|
-
RUN .evergreen/patch-debuggers /opt/rubies
|
289
|
-
<% end %>
|
290
|
-
|
291
|
-
<% end %>
|
292
|
-
|
293
|
-
<% if fle? %>
|
294
|
-
RUN curl --retry 3 -fL "https://s3.amazonaws.com/mciuploads/libmongocrypt/all/master/latest/libmongocrypt-all.tar.gz" |tar zxf -
|
295
|
-
|
296
|
-
<%= "ENV LIBMONGOCRYPT_PATH #{libmongocrypt_path}" %>
|
297
|
-
<% end %>
|
298
|
-
|
299
|
-
<% if preload? %>
|
300
|
-
ENV DOCKER_PRELOAD=1
|
301
|
-
<% end %>
|
302
|
-
|
303
|
-
ENV MONGO_ORCHESTRATION_HOME=/tmpfs \
|
304
|
-
PROJECT_DIRECTORY=/app \
|
305
|
-
<%= @env.map { |k, v| %Q`#{k}="#{v.gsub('$', "\\$").gsub('"', "\\\"")}"` }.join(" \\\n ") %>
|
306
|
-
|
307
|
-
<% if interactive? %>
|
308
|
-
ENV INTERACTIVE=1
|
309
|
-
<% end %>
|
310
|
-
|
311
|
-
COPY . .
|
312
|
-
|
313
|
-
RUN bash -c '. .evergreen/download-mongodb.sh && get_distro && get_mongodb_download_url_for "$DISTRO" "<%= server_version %>" && curl --retry 3 -fL $MONGODB_DOWNLOAD_URL |tar xzf - && mv mongo*/ /opt/mongodb'
|
314
|
-
ENV USE_OPT_MONGODB=1 USE_SYSTEM_PYTHON_PACKAGES=1
|
315
|
-
|
316
|
-
<% if expose? %>
|
317
|
-
|
318
|
-
<% ports = [] %>
|
319
|
-
|
320
|
-
<% 0.upto(num_exposed_ports-1) do |i| %>
|
321
|
-
<% ports << 27017 + i %>
|
322
|
-
<% end %>
|
323
|
-
|
324
|
-
<% if @env['OCSP_ALGORITHM'] %>
|
325
|
-
<% ports << 8100 %>
|
326
|
-
<% end %>
|
327
|
-
|
328
|
-
EXPOSE <%= ports.map(&:to_s).join(' ') %>
|
329
|
-
|
330
|
-
<% end %>
|
@@ -1,16 +0,0 @@
|
|
1
|
-
# Modeled after
|
2
|
-
# https://github.com/mongodb-labs/drivers-evergreen-tools/blob/master/.evergreen/run-load-balancer.sh
|
3
|
-
|
4
|
-
defaults
|
5
|
-
mode tcp
|
6
|
-
timeout connect 7s
|
7
|
-
timeout client 55s
|
8
|
-
timeout server 55s
|
9
|
-
|
10
|
-
frontend mongos_frontend
|
11
|
-
bind *:27017
|
12
|
-
use_backend mongos_backend
|
13
|
-
|
14
|
-
backend mongos_backend
|
15
|
-
mode tcp
|
16
|
-
server mongos_one 127.0.0.1:27117 check
|
@@ -1,17 +0,0 @@
|
|
1
|
-
# Modeled after
|
2
|
-
# https://github.com/mongodb-labs/drivers-evergreen-tools/blob/master/.evergreen/run-load-balancer.sh
|
3
|
-
|
4
|
-
defaults
|
5
|
-
mode tcp
|
6
|
-
timeout connect 7s
|
7
|
-
timeout client 55s
|
8
|
-
timeout server 55s
|
9
|
-
|
10
|
-
frontend mongos_frontend
|
11
|
-
bind *:27017
|
12
|
-
use_backend mongos_backend
|
13
|
-
|
14
|
-
backend mongos_backend
|
15
|
-
mode tcp
|
16
|
-
server mongos_one 127.0.0.1:27117 check
|
17
|
-
server mongos_two 127.0.0.1:27118 check
|
data/spec/shared/shlib/config.sh
DELETED
@@ -1,27 +0,0 @@
|
|
1
|
-
show_local_instructions_impl() {
|
2
|
-
local arch="$1"
|
3
|
-
shift
|
4
|
-
|
5
|
-
echo To test this configuration locally:
|
6
|
-
local params=
|
7
|
-
while test -n "$1"; do
|
8
|
-
key="$1"
|
9
|
-
shift
|
10
|
-
# ${!foo} syntax is bash specific:
|
11
|
-
# https://stackoverflow.com/questions/14049057/bash-expand-variable-in-a-variable
|
12
|
-
value="${!key}"
|
13
|
-
if test -n "$value"; then
|
14
|
-
params="$params $key=$value"
|
15
|
-
fi
|
16
|
-
done
|
17
|
-
|
18
|
-
# $0 has the current script being executed which is also the script that
|
19
|
-
# was initially invoked EXCEPT for the AWS configurations which use the
|
20
|
-
# wrapper script.
|
21
|
-
if echo "$AUTH" |grep -q ^aws; then
|
22
|
-
script=.evergreen/run-tests-aws-auth.sh
|
23
|
-
else
|
24
|
-
script="$0"
|
25
|
-
fi
|
26
|
-
echo ./.evergreen/test-on-docker -d $arch $params -s "$script"
|
27
|
-
}
|