mongoid 8.0.5 → 8.1.0
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
- checksums.yaml.gz.sig +0 -0
- data/CHANGELOG.md +3 -3
- data/README.md +3 -3
- data/Rakefile +0 -25
- data/lib/config/locales/en.yml +46 -14
- data/lib/mongoid/association/accessors.rb +2 -2
- data/lib/mongoid/association/builders.rb +1 -1
- data/lib/mongoid/association/embedded/batchable.rb +2 -2
- data/lib/mongoid/association/embedded/embedded_in/buildable.rb +2 -2
- data/lib/mongoid/association/embedded/embedded_in/proxy.rb +2 -1
- data/lib/mongoid/association/embedded/embeds_many/buildable.rb +3 -2
- data/lib/mongoid/association/embedded/embeds_many/proxy.rb +6 -6
- data/lib/mongoid/association/embedded/embeds_one/buildable.rb +1 -1
- data/lib/mongoid/association/embedded/embeds_one/proxy.rb +1 -1
- data/lib/mongoid/association/nested/one.rb +40 -2
- data/lib/mongoid/association/proxy.rb +1 -1
- data/lib/mongoid/association/referenced/counter_cache.rb +2 -2
- data/lib/mongoid/association/referenced/has_and_belongs_to_many/proxy.rb +1 -1
- data/lib/mongoid/association/referenced/has_many/enumerable.rb +2 -2
- data/lib/mongoid/association/referenced/has_many/proxy.rb +3 -3
- data/lib/mongoid/association/reflections.rb +2 -2
- data/lib/mongoid/atomic.rb +0 -7
- data/lib/mongoid/attributes/dynamic.rb +1 -1
- data/lib/mongoid/attributes/nested.rb +2 -2
- data/lib/mongoid/attributes/projector.rb +1 -1
- data/lib/mongoid/attributes/readonly.rb +1 -1
- data/lib/mongoid/attributes.rb +8 -2
- data/lib/mongoid/changeable.rb +107 -5
- data/lib/mongoid/clients/storage_options.rb +2 -5
- data/lib/mongoid/clients/validators/storage.rb +1 -13
- data/lib/mongoid/collection_configurable.rb +58 -0
- data/lib/mongoid/composable.rb +2 -0
- data/lib/mongoid/config/defaults.rb +60 -0
- data/lib/mongoid/config/validators/async_query_executor.rb +24 -0
- data/lib/mongoid/config/validators.rb +1 -0
- data/lib/mongoid/config.rb +101 -0
- data/lib/mongoid/contextual/atomic.rb +1 -1
- data/lib/mongoid/contextual/memory.rb +233 -33
- data/lib/mongoid/contextual/mongo/documents_loader.rb +177 -0
- data/lib/mongoid/contextual/mongo.rb +373 -113
- data/lib/mongoid/contextual/none.rb +162 -7
- data/lib/mongoid/contextual.rb +12 -0
- data/lib/mongoid/criteria/findable.rb +2 -2
- data/lib/mongoid/criteria/includable.rb +4 -3
- data/lib/mongoid/criteria/queryable/key.rb +1 -1
- data/lib/mongoid/criteria/queryable/mergeable.rb +1 -1
- data/lib/mongoid/criteria/queryable/optional.rb +8 -8
- data/lib/mongoid/criteria/queryable/selectable.rb +43 -12
- data/lib/mongoid/criteria.rb +6 -5
- data/lib/mongoid/deprecable.rb +1 -1
- data/lib/mongoid/errors/create_collection_failure.rb +33 -0
- data/lib/mongoid/errors/drop_collection_failure.rb +27 -0
- data/lib/mongoid/errors/immutable_attribute.rb +26 -0
- data/lib/mongoid/errors/invalid_async_query_executor.rb +25 -0
- data/lib/mongoid/errors/invalid_global_executor_concurrency.rb +22 -0
- data/lib/mongoid/errors/invalid_storage_parent.rb +2 -0
- data/lib/mongoid/errors.rb +4 -1
- data/lib/mongoid/extensions/object.rb +2 -2
- data/lib/mongoid/extensions/time.rb +2 -0
- data/lib/mongoid/fields/localized.rb +10 -0
- data/lib/mongoid/fields/standard.rb +10 -0
- data/lib/mongoid/fields.rb +69 -13
- data/lib/mongoid/findable.rb +27 -3
- data/lib/mongoid/interceptable.rb +7 -6
- data/lib/mongoid/matcher/eq_impl.rb +1 -1
- data/lib/mongoid/matcher/type.rb +1 -1
- data/lib/mongoid/persistable/creatable.rb +1 -0
- data/lib/mongoid/persistable/deletable.rb +1 -1
- data/lib/mongoid/persistable/savable.rb +13 -1
- data/lib/mongoid/persistable/unsettable.rb +2 -2
- data/lib/mongoid/persistable/updatable.rb +51 -1
- data/lib/mongoid/persistable/upsertable.rb +20 -1
- data/lib/mongoid/persistable.rb +3 -0
- data/lib/mongoid/query_cache.rb +5 -1
- data/lib/mongoid/railties/database.rake +7 -2
- data/lib/mongoid/reloadable.rb +5 -3
- data/lib/mongoid/stateful.rb +22 -1
- data/lib/mongoid/tasks/database.rake +12 -0
- data/lib/mongoid/tasks/database.rb +20 -0
- data/lib/mongoid/utils.rb +22 -0
- data/lib/mongoid/validatable/macros.rb +5 -5
- data/lib/mongoid/validatable.rb +4 -1
- data/lib/mongoid/version.rb +1 -1
- data/lib/mongoid/warnings.rb +17 -1
- data/lib/mongoid.rb +16 -3
- data/spec/integration/app_spec.rb +2 -2
- data/spec/integration/callbacks_models.rb +37 -0
- data/spec/integration/callbacks_spec.rb +134 -0
- data/spec/integration/discriminator_key_spec.rb +4 -5
- data/spec/integration/i18n_fallbacks_spec.rb +3 -2
- data/spec/mongoid/association/embedded/embedded_in/proxy_spec.rb +27 -0
- data/spec/mongoid/association/embedded/embeds_many/proxy_spec.rb +20 -25
- data/spec/mongoid/association/embedded/embeds_many_models.rb +1 -0
- data/spec/mongoid/association/embedded/embeds_one/proxy_spec.rb +15 -2
- data/spec/mongoid/association/referenced/belongs_to_spec.rb +2 -18
- data/spec/mongoid/association/referenced/has_and_belongs_to_many/proxy_spec.rb +5 -27
- data/spec/mongoid/association/referenced/has_many/proxy_spec.rb +9 -50
- data/spec/mongoid/association/syncable_spec.rb +1 -1
- data/spec/mongoid/attributes_spec.rb +3 -6
- data/spec/mongoid/changeable_spec.rb +299 -24
- data/spec/mongoid/clients_spec.rb +122 -13
- data/spec/mongoid/collection_configurable_spec.rb +158 -0
- data/spec/mongoid/config/defaults_spec.rb +160 -0
- data/spec/mongoid/config_spec.rb +154 -18
- data/spec/mongoid/contextual/memory_spec.rb +332 -76
- data/spec/mongoid/contextual/mongo/documents_loader_spec.rb +187 -0
- data/spec/mongoid/contextual/mongo_spec.rb +995 -36
- data/spec/mongoid/contextual/none_spec.rb +49 -2
- data/spec/mongoid/copyable_spec.rb +3 -11
- data/spec/mongoid/criteria/queryable/extensions/string_spec.rb +4 -10
- data/spec/mongoid/criteria/queryable/options_spec.rb +1 -1
- data/spec/mongoid/criteria/queryable/selectable_logical_spec.rb +419 -0
- data/spec/mongoid/criteria/queryable/selectable_spec.rb +1 -1
- data/spec/mongoid/criteria/queryable/selector_spec.rb +1 -1
- data/spec/mongoid/criteria_projection_spec.rb +1 -4
- data/spec/mongoid/criteria_spec.rb +5 -9
- data/spec/mongoid/errors/readonly_document_spec.rb +2 -2
- data/spec/mongoid/extensions/time_spec.rb +8 -43
- data/spec/mongoid/extensions/time_with_zone_spec.rb +7 -52
- data/spec/mongoid/fields/localized_spec.rb +46 -28
- data/spec/mongoid/fields_spec.rb +136 -34
- data/spec/mongoid/findable_spec.rb +391 -34
- data/spec/mongoid/indexable_spec.rb +16 -10
- data/spec/mongoid/interceptable_spec.rb +15 -3
- data/spec/mongoid/persistable/deletable_spec.rb +26 -6
- data/spec/mongoid/persistable/destroyable_spec.rb +26 -6
- data/spec/mongoid/persistable/incrementable_spec.rb +37 -0
- data/spec/mongoid/persistable/logical_spec.rb +37 -0
- data/spec/mongoid/persistable/poppable_spec.rb +36 -0
- data/spec/mongoid/persistable/pullable_spec.rb +72 -0
- data/spec/mongoid/persistable/pushable_spec.rb +72 -0
- data/spec/mongoid/persistable/renamable_spec.rb +36 -0
- data/spec/mongoid/persistable/savable_spec.rb +96 -0
- data/spec/mongoid/persistable/settable_spec.rb +37 -0
- data/spec/mongoid/persistable/unsettable_spec.rb +36 -0
- data/spec/mongoid/persistable/updatable_spec.rb +20 -28
- data/spec/mongoid/persistable/upsertable_spec.rb +80 -6
- data/spec/mongoid/persistence_context_spec.rb +7 -57
- data/spec/mongoid/query_cache_spec.rb +56 -61
- data/spec/mongoid/reloadable_spec.rb +24 -28
- data/spec/mongoid/scopable_spec.rb +70 -0
- data/spec/mongoid/serializable_spec.rb +9 -30
- data/spec/mongoid/stateful_spec.rb +122 -8
- data/spec/mongoid/tasks/database_rake_spec.rb +74 -0
- data/spec/mongoid/tasks/database_spec.rb +127 -0
- data/spec/mongoid/timestamps_spec.rb +9 -11
- data/spec/mongoid/touchable_spec.rb +277 -5
- data/spec/mongoid/touchable_spec_models.rb +3 -1
- data/spec/mongoid/traversable_spec.rb +9 -24
- data/spec/mongoid/validatable/uniqueness_spec.rb +2 -3
- data/spec/mongoid_spec.rb +36 -10
- data/spec/shared/lib/mrss/docker_runner.rb +7 -0
- data/spec/shared/lib/mrss/event_subscriber.rb +15 -5
- data/spec/shared/lib/mrss/lite_constraints.rb +10 -2
- data/spec/shared/lib/mrss/server_version_registry.rb +16 -23
- data/spec/shared/lib/mrss/utils.rb +28 -6
- data/spec/shared/share/Dockerfile.erb +36 -40
- data/spec/shared/shlib/server.sh +32 -8
- data/spec/shared/shlib/set_env.sh +4 -4
- data/spec/spec_helper.rb +5 -0
- data/spec/support/immutable_ids.rb +118 -0
- data/spec/support/macros.rb +47 -15
- data/spec/support/models/artist.rb +0 -1
- data/spec/support/models/band.rb +1 -0
- data/spec/support/models/book.rb +1 -0
- data/spec/support/models/building.rb +2 -0
- data/spec/support/models/cover.rb +10 -0
- data/spec/support/models/product.rb +1 -0
- data.tar.gz.sig +0 -0
- metadata +686 -650
- metadata.gz.sig +0 -0
- data/spec/mongoid/criteria/queryable/extensions/bignum_spec.rb +0 -60
- data/spec/mongoid/criteria/queryable/extensions/fixnum_spec.rb +0 -60
@@ -3,13 +3,35 @@
|
|
3
3
|
|
4
4
|
module Mrss
|
5
5
|
module Utils
|
6
|
+
extend self
|
6
7
|
|
7
|
-
|
8
|
-
|
9
|
-
|
10
|
-
|
11
|
-
|
12
|
-
|
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
|
+
)
|
13
35
|
end
|
14
36
|
end
|
15
37
|
end
|
@@ -7,13 +7,13 @@
|
|
7
7
|
<%
|
8
8
|
|
9
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'
|
10
|
+
# server_version = '4.3.3'
|
11
11
|
server_url = "http://downloads.10gen.com/linux/mongodb-linux-x86_64-enterprise-#{distro}-#{server_version}.tgz"
|
12
12
|
server_archive_basename = File.basename(server_url)
|
13
13
|
server_extracted_dir = server_archive_basename.sub(/\.(tar\.gz|tgz)$/, '')
|
14
14
|
|
15
15
|
# When changing, also update the hash in shlib/set_env.sh.
|
16
|
-
TOOLCHAIN_VERSION='
|
16
|
+
TOOLCHAIN_VERSION='e8c60866f54bed7e336a37df3a97d6ae1b971b7d'
|
17
17
|
|
18
18
|
def ruby_toolchain_url(ruby)
|
19
19
|
"http://boxes.10gen.com/build/toolchain-drivers/mongo-ruby-driver/#{TOOLCHAIN_VERSION}/#{distro}/#{ruby}.tar.xz"
|
@@ -77,25 +77,31 @@ ENV DOCKER=1
|
|
77
77
|
# therefore install python-pip in all configurations here.
|
78
78
|
|
79
79
|
<% packages = %w(
|
80
|
-
procps lsb-release bzip2 curl zsh
|
80
|
+
procps lsb-release bzip2 curl wget gpg zsh
|
81
81
|
git make gcc libyaml-0-2 libgmp-dev zlib1g-dev libsnappy-dev
|
82
82
|
krb5-user krb5-kdc krb5-admin-server libsasl2-dev libsasl2-modules-gssapi-mit
|
83
83
|
haproxy
|
84
84
|
python3-pip
|
85
|
-
tzdata shared-mime-info
|
85
|
+
tzdata shared-mime-info software-properties-common
|
86
86
|
) %>
|
87
87
|
|
88
88
|
<% if distro =~ /ubuntu2004/ %>
|
89
89
|
<% packages << 'libsnmp35' %>
|
90
|
+
<% elsif distro =~ /ubuntu2204|debian11/ %>
|
91
|
+
<% packages << 'libsnmp40' %>
|
90
92
|
<% else %>
|
91
93
|
<% packages << 'libsnmp30' %>
|
92
94
|
<% end %>
|
93
95
|
|
94
|
-
<% if distro !~ /ubuntu2004/ %>
|
96
|
+
<% if distro !~ /ubuntu2004|ubuntu2204|debian11/ %>
|
95
97
|
<% packages << 'python-pip' %>
|
96
98
|
<% end %>
|
97
99
|
|
98
|
-
<% if distro =~ /
|
100
|
+
<% if distro =~ /ubuntu2204|debian11/ %>
|
101
|
+
<% packages << 'python3-venv' %>
|
102
|
+
<% end %>
|
103
|
+
|
104
|
+
<% if distro =~ /debian10|ubuntu2204|debian11/ %>
|
99
105
|
<% packages << 'openjdk-11-jdk-headless' %>
|
100
106
|
<% elsif distro =~ /ubuntu1404/ %>
|
101
107
|
# Ubuntu 14.04 only has openjdk 7, this is too old to be useful
|
@@ -105,31 +111,37 @@ ENV DOCKER=1
|
|
105
111
|
|
106
112
|
# ubuntu1404, ubuntu1604: libcurl3
|
107
113
|
# ubuntu1804, ubuntu2004, debian10: libcurl4
|
108
|
-
<% if distro =~ /ubuntu1804|ubuntu2004|debian10/ %>
|
114
|
+
<% if distro =~ /ubuntu1804|ubuntu2004|ubuntu2204|debian10|debian11/ %>
|
109
115
|
<% packages << 'libcurl4' %>
|
110
116
|
<% else %>
|
111
117
|
<% packages << 'libcurl3' %>
|
112
118
|
<% end %>
|
113
119
|
|
114
|
-
<% if distro =~ /ubuntu1804|ubuntu2004/ %>
|
120
|
+
<% if distro =~ /ubuntu1804|ubuntu2004|ubuntu2204/ %>
|
115
121
|
<% packages << 'nodejs' %>
|
116
122
|
<% end %>
|
117
123
|
|
118
|
-
<% if distro =~ /ubuntu2004/ %>
|
119
|
-
<% packages += %w(ruby
|
124
|
+
<% if distro =~ /ubuntu2004|ubuntu2204/ %>
|
125
|
+
<% packages += %w(ruby bundler) %>
|
120
126
|
<% end %>
|
121
127
|
|
122
128
|
RUN apt-get update && apt-get install -y <%= packages.join(' ') %>
|
123
|
-
|
129
|
+
|
130
|
+
<% if ubuntu? %>
|
131
|
+
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
|
132
|
+
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
|
133
|
+
<% end %>
|
134
|
+
RUN apt-get update && apt-get install -y cmake
|
135
|
+
|
124
136
|
<% else %>
|
125
137
|
|
126
138
|
<% if distro =~ /rhel6/ %>
|
127
|
-
|
139
|
+
|
128
140
|
# CentOS 6 is dead - to use it retrieve the packages from vault:
|
129
141
|
# https://stackoverflow.com/questions/53562691/error-cannot-retrieve-repository-metadata-repomd-xml-for-repository-base-pl
|
130
|
-
|
142
|
+
|
131
143
|
<%
|
132
|
-
|
144
|
+
|
133
145
|
cfg = <<-CFG
|
134
146
|
[base]
|
135
147
|
name=CentOS-$releasever - Base
|
@@ -141,11 +153,11 @@ gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6
|
|
141
153
|
CFG
|
142
154
|
|
143
155
|
%>
|
144
|
-
|
156
|
+
|
145
157
|
RUN printf "<%= cfg.gsub("\n", "\\n") %>" >/etc/yum.repos.d/CentOS-Base.repo
|
146
|
-
|
158
|
+
|
147
159
|
<% end %>
|
148
|
-
|
160
|
+
|
149
161
|
# Enterprise server: net-snmp
|
150
162
|
# lsb_release: redhat-lsb-core
|
151
163
|
# our runner scripts: which
|
@@ -162,23 +174,8 @@ CFG
|
|
162
174
|
|
163
175
|
RUN yum install -y redhat-lsb-core which git gcc libyaml krb5-server \
|
164
176
|
krb5-workstation cyrus-sasl-devel cyrus-sasl-gssapi java-1.8.0-openjdk \
|
165
|
-
net-snmp
|
177
|
+
net-snmp python38 python38-devel cmake nodejs
|
166
178
|
|
167
|
-
<% if distro =~ /rhel6/ %>
|
168
|
-
|
169
|
-
# RHEL 6 ships with Python 2.6.
|
170
|
-
|
171
|
-
RUN yum install -y centos-release-scl && \
|
172
|
-
yum install -y python27-python python27-python-devel
|
173
|
-
ENV PATH=/opt/rh/python27/root/usr/bin:$PATH \
|
174
|
-
LD_LIBRARY_PATH=/opt/rh/python27/root/usr/lib64
|
175
|
-
|
176
|
-
<% else %>
|
177
|
-
|
178
|
-
RUN yum install -y python-devel
|
179
|
-
|
180
|
-
<% end %>
|
181
|
-
|
182
179
|
<% end %>
|
183
180
|
|
184
181
|
<% if preload? %>
|
@@ -220,7 +217,7 @@ CFG
|
|
220
217
|
<% when 'git' %>
|
221
218
|
# dateutil dependency is missing in mtools: https://github.com/rueckstiess/mtools/issues/864
|
222
219
|
RUN python3 -m pip install virtualenv 'pymongo>=4' python-dateutil psutil
|
223
|
-
|
220
|
+
|
224
221
|
# Install mtools from git because released versions do not work with pymongo 4.0
|
225
222
|
RUN git clone https://github.com/p-mongodb/mtools && \
|
226
223
|
cd mtools && \
|
@@ -234,7 +231,7 @@ CFG
|
|
234
231
|
<% if @env.fetch('MONGODB_VERSION') >= '4.4' %>
|
235
232
|
# ubuntu1604 installs MarkupSafe 0.0.0 here instead of 2.0.0+
|
236
233
|
# as specified by dependencies, causing OCSP mock to not work.
|
237
|
-
RUN python3 -mpip install asn1crypto oscrypto flask --upgrade
|
234
|
+
RUN python3 -mpip install asn1crypto oscrypto flask --upgrade --ignore-installed
|
238
235
|
<% end %>
|
239
236
|
|
240
237
|
# FLE is tested against 4.0+ servers.
|
@@ -243,7 +240,7 @@ CFG
|
|
243
240
|
# boto3~=1.19 cryptography~=3.4.8 pykmip~=0.10.0
|
244
241
|
# cryptography does not install due to lacking setuptools_rust
|
245
242
|
# (either that version or anything that isn't part of system packages)
|
246
|
-
RUN python3 -mpip install boto3~=1.19 cryptography pykmip~=0.10.0
|
243
|
+
RUN python3 -mpip install boto3~=1.19 cryptography pykmip~=0.10.0 'sqlalchemy<2.0.0'
|
247
244
|
<% end %>
|
248
245
|
|
249
246
|
<% unless ruby_head? || system_ruby? %>
|
@@ -255,10 +252,6 @@ CFG
|
|
255
252
|
|
256
253
|
<% end %>
|
257
254
|
|
258
|
-
RUN curl --retry 3 -fL <%= server_download_url %> |tar xzf - && \
|
259
|
-
mv mongo*/ /opt/mongodb
|
260
|
-
ENV USE_OPT_MONGODB=1 USE_SYSTEM_PYTHON_PACKAGES=1
|
261
|
-
|
262
255
|
<% end %>
|
263
256
|
|
264
257
|
<% if distro =~ /debian|ubuntu/ %>
|
@@ -308,6 +301,9 @@ ENV MONGO_ORCHESTRATION_HOME=/tmpfs \
|
|
308
301
|
|
309
302
|
COPY . .
|
310
303
|
|
304
|
+
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'
|
305
|
+
ENV USE_OPT_MONGODB=1 USE_SYSTEM_PYTHON_PACKAGES=1
|
306
|
+
|
311
307
|
<% if expose? %>
|
312
308
|
|
313
309
|
<% ports = [] %>
|
data/spec/shared/shlib/server.sh
CHANGED
@@ -71,12 +71,18 @@ prepare_server_from_url() {
|
|
71
71
|
export PATH="$BINDIR":$PATH
|
72
72
|
}
|
73
73
|
|
74
|
-
|
74
|
+
install_mlaunch_venv() {
|
75
75
|
python3 -V || true
|
76
|
-
if ! python3 -m
|
76
|
+
if ! python3 -m venv -h >/dev/null; then
|
77
77
|
# Current virtualenv fails with
|
78
78
|
# https://github.com/pypa/virtualenv/issues/1630
|
79
|
-
python3 -m pip install
|
79
|
+
python3 -m pip install venv --user
|
80
|
+
fi
|
81
|
+
if ! python3 -m ensurepip -h > /dev/null; then
|
82
|
+
# Debian11/Ubuntu2204 have venv installed, but it is nonfunctional unless
|
83
|
+
# the python3-venv package is also installed (it lacks the ensurepip
|
84
|
+
# module).
|
85
|
+
sudo apt-get install --yes python3-venv
|
80
86
|
fi
|
81
87
|
if test "$USE_SYSTEM_PYTHON_PACKAGES" = 1 &&
|
82
88
|
python3 -m pip list |grep mtools
|
@@ -84,14 +90,19 @@ install_mlaunch_virtualenv() {
|
|
84
90
|
# Use the existing mtools-legacy
|
85
91
|
:
|
86
92
|
else
|
87
|
-
|
88
|
-
|
89
|
-
|
93
|
+
# Spawn a virtual environment, but only if one is not already
|
94
|
+
# active...
|
95
|
+
if test -z "$VIRTUAL_ENV"; then
|
96
|
+
venvpath="$MONGO_ORCHESTRATION_HOME"/venv
|
97
|
+
python3 -m venv $venvpath
|
98
|
+
. $venvpath/bin/activate
|
99
|
+
fi
|
100
|
+
|
90
101
|
# [mlaunch] does not work:
|
91
102
|
# https://github.com/rueckstiess/mtools/issues/856
|
92
103
|
# dateutil dependency is missing in mtools: https://github.com/rueckstiess/mtools/issues/864
|
93
104
|
#pip install 'mtools==1.7' 'pymongo==4.1' python-dateutil psutil
|
94
|
-
|
105
|
+
|
95
106
|
# dateutil dependency is missing in mtools: https://github.com/rueckstiess/mtools/issues/864
|
96
107
|
pip install 'mtools-legacy[mlaunch]' 'pymongo<4' python-dateutil
|
97
108
|
fi
|
@@ -158,6 +169,19 @@ install_mlaunch_git() {
|
|
158
169
|
fi
|
159
170
|
}
|
160
171
|
|
172
|
+
install_cmake() {
|
173
|
+
if ! command -v cmake &> /dev/null; then
|
174
|
+
if ! command -v apt-get &> /dev/null; then
|
175
|
+
# no apt-get; assume RHEL
|
176
|
+
sudo yum -y install cmake libarchive
|
177
|
+
else
|
178
|
+
sudo apt-get install --yes cmake
|
179
|
+
fi
|
180
|
+
else
|
181
|
+
echo 'cmake is present'
|
182
|
+
fi
|
183
|
+
}
|
184
|
+
|
161
185
|
# This function sets followong global variables:
|
162
186
|
# server_cert_path
|
163
187
|
# server_ca_path
|
@@ -173,7 +197,7 @@ calculate_server_args() {
|
|
173
197
|
fi
|
174
198
|
|
175
199
|
if test $mongo_version = latest; then
|
176
|
-
mongo_version=
|
200
|
+
mongo_version=70
|
177
201
|
fi
|
178
202
|
|
179
203
|
local args="--setParameter enableTestCommands=1"
|
@@ -1,5 +1,5 @@
|
|
1
1
|
# When changing, also update the hash in share/Dockerfile.
|
2
|
-
TOOLCHAIN_VERSION=
|
2
|
+
TOOLCHAIN_VERSION=e8c60866f54bed7e336a37df3a97d6ae1b971b7d
|
3
3
|
|
4
4
|
set_env_java() {
|
5
5
|
ls -l /opt || true
|
@@ -53,7 +53,7 @@ set_env_python() {
|
|
53
53
|
curl -fL --retry 3 https://github.com/p-mongodb/deps/raw/main/"$arch"-python37.tar.xz | \
|
54
54
|
tar xfJ - -C /opt
|
55
55
|
fi
|
56
|
-
|
56
|
+
|
57
57
|
if test -d /opt/python/3.7/bin; then
|
58
58
|
# Most Evergreen configurations.
|
59
59
|
export PATH=/opt/python/3.7/bin:$PATH
|
@@ -61,7 +61,7 @@ set_env_python() {
|
|
61
61
|
# Configurations that use Docker in Evergreen - these don't preload.
|
62
62
|
export PATH=/opt/python37/bin:$PATH
|
63
63
|
fi
|
64
|
-
|
64
|
+
|
65
65
|
python3 -V
|
66
66
|
fi
|
67
67
|
}
|
@@ -78,7 +78,7 @@ set_env_node() {
|
|
78
78
|
# Node from toolchain in Evergreen
|
79
79
|
export PATH=/opt/node/bin:$PATH
|
80
80
|
fi
|
81
|
-
|
81
|
+
|
82
82
|
node -v
|
83
83
|
}
|
84
84
|
|
data/spec/spec_helper.rb
CHANGED
@@ -124,6 +124,11 @@ end
|
|
124
124
|
|
125
125
|
I18n.config.enforce_available_locales = false
|
126
126
|
|
127
|
+
|
128
|
+
if %w(yes true 1).include?((ENV['TEST_I18N_FALLBACKS'] || '').downcase)
|
129
|
+
require "i18n/backend/fallbacks"
|
130
|
+
end
|
131
|
+
|
127
132
|
# The user must be created before any of the tests are loaded, until
|
128
133
|
# https://jira.mongodb.org/browse/MONGOID-4827 is implemented.
|
129
134
|
client = Mongo::Client.new(SpecConfig.instance.addresses, server_selection_timeout: 3.03)
|
@@ -0,0 +1,118 @@
|
|
1
|
+
module Mongoid
|
2
|
+
module ImmutableIds
|
3
|
+
def immutable_id_examples_as(name)
|
4
|
+
shared_examples_for name do
|
5
|
+
shared_examples 'a persisted document' do
|
6
|
+
it 'should ignore the change and issue a warning' do
|
7
|
+
expect(Mongoid::Warnings).to receive(:warn_mutable_ids)
|
8
|
+
expect { invoke_operation! }.not_to raise_error
|
9
|
+
expect(id_is_unchanged).not_to be legacy_behavior_expects_id_to_change
|
10
|
+
end
|
11
|
+
|
12
|
+
context 'when immutable_ids is true' do
|
13
|
+
before { Mongoid::Config.immutable_ids = true }
|
14
|
+
after { Mongoid::Config.immutable_ids = false }
|
15
|
+
|
16
|
+
it 'should disallow _id to be updated' do
|
17
|
+
expect { invoke_operation! }
|
18
|
+
.to raise_error(Mongoid::Errors::ImmutableAttribute)
|
19
|
+
end
|
20
|
+
|
21
|
+
context 'when id is set to the existing value' do
|
22
|
+
let(:new_id_value) { object._id }
|
23
|
+
|
24
|
+
it 'should allow the update to proceed' do
|
25
|
+
expect { invoke_operation! }
|
26
|
+
.not_to raise_error
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
context 'when the field is _id' do
|
33
|
+
let(:new_id_value) { 1234 }
|
34
|
+
|
35
|
+
context 'when the document is top-level' do
|
36
|
+
let(:legacy_behavior_expects_id_to_change) { false }
|
37
|
+
|
38
|
+
context 'when the document is new' do
|
39
|
+
let(:object) { Person.new }
|
40
|
+
|
41
|
+
it 'should allow _id to be updated' do
|
42
|
+
invoke_operation!
|
43
|
+
expect(object.new_record?).to be false
|
44
|
+
expect(object.reload._id).to be == new_id_value
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
context 'when the document has been persisted' do
|
49
|
+
let(:object) { Person.create }
|
50
|
+
let!(:original_id) { object._id }
|
51
|
+
let(:id_is_unchanged) { Person.exists?(original_id) }
|
52
|
+
|
53
|
+
it_behaves_like 'a persisted document'
|
54
|
+
end
|
55
|
+
end
|
56
|
+
|
57
|
+
context 'when the document is embedded' do
|
58
|
+
let(:parent) { Person.create }
|
59
|
+
let(:legacy_behavior_expects_id_to_change) { true }
|
60
|
+
|
61
|
+
context 'when the document is new' do
|
62
|
+
let(:object) { parent.favorites.new }
|
63
|
+
|
64
|
+
it 'should allow _id to be updated' do
|
65
|
+
invoke_operation!
|
66
|
+
expect(object.new_record?).to be false
|
67
|
+
expect(parent.reload.favorites.first._id).to be == new_id_value
|
68
|
+
end
|
69
|
+
end
|
70
|
+
|
71
|
+
context 'when the document has been persisted' do
|
72
|
+
let(:object) { parent.favorites.create }
|
73
|
+
let!(:original_id) { object._id }
|
74
|
+
let(:id_is_unchanged) { parent.favorites.where(_id: original_id).exists? }
|
75
|
+
|
76
|
+
it_behaves_like 'a persisted document'
|
77
|
+
|
78
|
+
context 'updating embeds_one via parent' do
|
79
|
+
context 'when immutable_ids is false' do
|
80
|
+
before { expect(Mongoid::Config.immutable_ids).to be false }
|
81
|
+
|
82
|
+
it 'should ignore the change' do
|
83
|
+
expect(Mongoid::Warnings).to receive(:warn_mutable_ids)
|
84
|
+
|
85
|
+
parent.pet = pet = Pet.new
|
86
|
+
parent.save
|
87
|
+
|
88
|
+
original_id = pet._id
|
89
|
+
new_id = BSON::ObjectId.new
|
90
|
+
|
91
|
+
expect { parent.update(pet: { _id: new_id }) }.not_to raise_error
|
92
|
+
expect(parent.reload.pet._id.to_s).to be == original_id.to_s
|
93
|
+
end
|
94
|
+
end
|
95
|
+
|
96
|
+
context 'when immutable_ids is true' do
|
97
|
+
before { Mongoid::Config.immutable_ids = true }
|
98
|
+
after { Mongoid::Config.immutable_ids = false }
|
99
|
+
|
100
|
+
it 'should raise an exception' do
|
101
|
+
parent.pet = pet = Pet.new
|
102
|
+
parent.save
|
103
|
+
|
104
|
+
original_id = pet._id
|
105
|
+
new_id = BSON::ObjectId.new
|
106
|
+
|
107
|
+
expect { parent.update(pet: { _id: new_id }) }
|
108
|
+
.to raise_error(Mongoid::Errors::ImmutableAttribute)
|
109
|
+
end
|
110
|
+
end
|
111
|
+
end
|
112
|
+
end
|
113
|
+
end
|
114
|
+
end
|
115
|
+
end
|
116
|
+
end
|
117
|
+
end
|
118
|
+
end
|
data/spec/support/macros.rb
CHANGED
@@ -2,9 +2,6 @@
|
|
2
2
|
|
3
3
|
module Mongoid
|
4
4
|
module Macros
|
5
|
-
class I18nBackendWithFallbacks < I18n::Backend::Simple
|
6
|
-
include I18n::Backend::Fallbacks
|
7
|
-
end
|
8
5
|
|
9
6
|
def use_spec_mongoid_config
|
10
7
|
around do |example|
|
@@ -43,18 +40,6 @@ module Mongoid
|
|
43
40
|
end
|
44
41
|
end
|
45
42
|
|
46
|
-
def with_i18n_fallbacks
|
47
|
-
require_fallbacks
|
48
|
-
|
49
|
-
around do |example|
|
50
|
-
old_backend = I18n.backend
|
51
|
-
I18n.backend = I18nBackendWithFallbacks.new
|
52
|
-
example.run
|
53
|
-
ensure
|
54
|
-
I18n.backend = old_backend
|
55
|
-
end
|
56
|
-
end
|
57
|
-
|
58
43
|
def driver_config_override(key, value)
|
59
44
|
around do |example|
|
60
45
|
existing = Mongo.send(key)
|
@@ -93,5 +78,52 @@ module Mongoid
|
|
93
78
|
end
|
94
79
|
end
|
95
80
|
end
|
81
|
+
|
82
|
+
def override_query_cache(enabled)
|
83
|
+
around do |example|
|
84
|
+
cache_enabled = Mongo::QueryCache.enabled?
|
85
|
+
Mongo::QueryCache.enabled = enabled
|
86
|
+
example.run
|
87
|
+
Mongo::QueryCache.enabled = cache_enabled
|
88
|
+
end
|
89
|
+
end
|
90
|
+
|
91
|
+
# Override the global persistence context.
|
92
|
+
#
|
93
|
+
# @param [ :client, :database ] component The component to override.
|
94
|
+
# @param [ Object ] value The value to override to.
|
95
|
+
def persistence_context_override(component, value)
|
96
|
+
around do |example|
|
97
|
+
meth = "#{component}_override"
|
98
|
+
old_value = Mongoid::Threaded.send(meth)
|
99
|
+
Mongoid::Threaded.send("#{meth}=", value)
|
100
|
+
example.run
|
101
|
+
Mongoid::Threaded.send("#{meth}=", old_value)
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
105
|
+
def time_zone_override(tz)
|
106
|
+
around do |example|
|
107
|
+
old_tz = Time.zone
|
108
|
+
Time.zone = tz
|
109
|
+
example.run
|
110
|
+
Time.zone = old_tz
|
111
|
+
end
|
112
|
+
end
|
113
|
+
|
114
|
+
def with_default_i18n_configs
|
115
|
+
around do |example|
|
116
|
+
I18n.locale = :en
|
117
|
+
I18n.default_locale = :en
|
118
|
+
I18n.try(:fallbacks=, I18n::Locale::Fallbacks.new)
|
119
|
+
I18n.enforce_available_locales = false
|
120
|
+
example.run
|
121
|
+
ensure
|
122
|
+
I18n.locale = :en
|
123
|
+
I18n.default_locale = :en
|
124
|
+
I18n.try(:fallbacks=, I18n::Locale::Fallbacks.new)
|
125
|
+
I18n.enforce_available_locales = false
|
126
|
+
end
|
127
|
+
end
|
96
128
|
end
|
97
129
|
end
|
data/spec/support/models/band.rb
CHANGED
data/spec/support/models/book.rb
CHANGED
data.tar.gz.sig
CHANGED
Binary file
|