arel_extensions 1.4.2 → 2.0.0.rc3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (140) hide show
  1. checksums.yaml +4 -4
  2. data/.codeclimate.yml +2 -1
  3. data/.gitignore +6 -7
  4. data/.rubocop.yml +3 -67
  5. data/.travis/oracle/download.js +152 -0
  6. data/.travis/oracle/download.sh +30 -0
  7. data/.travis/oracle/download_ojdbc.js +116 -0
  8. data/.travis/oracle/install.sh +34 -0
  9. data/.travis/setup_accounts.sh +9 -0
  10. data/.travis/sqlite3/extension-functions.sh +6 -0
  11. data/.travis.yml +223 -0
  12. data/Gemfile +28 -2
  13. data/README.md +90 -239
  14. data/Rakefile +30 -48
  15. data/TODO +1 -0
  16. data/appveyor.yml +22 -60
  17. data/arel_extensions.gemspec +14 -13
  18. data/functions.html +3 -3
  19. data/gemfiles/rails3.gemfile +10 -10
  20. data/gemfiles/rails4.gemfile +29 -0
  21. data/gemfiles/rails5_0.gemfile +29 -0
  22. data/gemfiles/rails5_1_4.gemfile +14 -14
  23. data/gemfiles/rails5_2.gemfile +14 -16
  24. data/init/mssql.sql +4 -4
  25. data/init/mysql.sql +38 -38
  26. data/init/oracle.sql +0 -0
  27. data/init/postgresql.sql +21 -21
  28. data/init/sqlite.sql +0 -0
  29. data/lib/arel_extensions/attributes.rb +3 -10
  30. data/lib/arel_extensions/boolean_functions.rb +14 -53
  31. data/lib/arel_extensions/common_sql_functions.rb +17 -16
  32. data/lib/arel_extensions/comparators.rb +28 -27
  33. data/lib/arel_extensions/date_duration.rb +13 -17
  34. data/lib/arel_extensions/insert_manager.rb +15 -18
  35. data/lib/arel_extensions/math.rb +53 -55
  36. data/lib/arel_extensions/math_functions.rb +39 -46
  37. data/lib/arel_extensions/nodes/abs.rb +1 -0
  38. data/lib/arel_extensions/nodes/blank.rb +2 -1
  39. data/lib/arel_extensions/nodes/case.rb +19 -20
  40. data/lib/arel_extensions/nodes/cast.rb +8 -10
  41. data/lib/arel_extensions/nodes/ceil.rb +1 -1
  42. data/lib/arel_extensions/nodes/coalesce.rb +4 -3
  43. data/lib/arel_extensions/nodes/collate.rb +10 -9
  44. data/lib/arel_extensions/nodes/concat.rb +18 -9
  45. data/lib/arel_extensions/nodes/date_diff.rb +26 -42
  46. data/lib/arel_extensions/nodes/duration.rb +3 -0
  47. data/lib/arel_extensions/nodes/find_in_set.rb +1 -0
  48. data/lib/arel_extensions/nodes/floor.rb +1 -1
  49. data/lib/arel_extensions/nodes/format.rb +8 -35
  50. data/lib/arel_extensions/nodes/formatted_number.rb +23 -22
  51. data/lib/arel_extensions/nodes/function.rb +37 -42
  52. data/lib/arel_extensions/nodes/is_null.rb +0 -0
  53. data/lib/arel_extensions/nodes/json.rb +39 -52
  54. data/lib/arel_extensions/nodes/length.rb +0 -5
  55. data/lib/arel_extensions/nodes/levenshtein_distance.rb +1 -1
  56. data/lib/arel_extensions/nodes/locate.rb +2 -1
  57. data/lib/arel_extensions/nodes/log10.rb +2 -1
  58. data/lib/arel_extensions/nodes/matches.rb +7 -5
  59. data/lib/arel_extensions/nodes/md5.rb +1 -0
  60. data/lib/arel_extensions/nodes/power.rb +5 -5
  61. data/lib/arel_extensions/nodes/rand.rb +1 -0
  62. data/lib/arel_extensions/nodes/repeat.rb +5 -3
  63. data/lib/arel_extensions/nodes/replace.rb +8 -16
  64. data/lib/arel_extensions/nodes/round.rb +6 -5
  65. data/lib/arel_extensions/nodes/soundex.rb +15 -15
  66. data/lib/arel_extensions/nodes/std.rb +21 -18
  67. data/lib/arel_extensions/nodes/substring.rb +16 -8
  68. data/lib/arel_extensions/nodes/then.rb +1 -1
  69. data/lib/arel_extensions/nodes/trim.rb +6 -4
  70. data/lib/arel_extensions/nodes/union.rb +8 -5
  71. data/lib/arel_extensions/nodes/union_all.rb +7 -4
  72. data/lib/arel_extensions/nodes/wday.rb +4 -0
  73. data/lib/arel_extensions/nodes.rb +1 -1
  74. data/lib/arel_extensions/null_functions.rb +5 -19
  75. data/lib/arel_extensions/predications.rb +43 -44
  76. data/lib/arel_extensions/railtie.rb +5 -5
  77. data/lib/arel_extensions/set_functions.rb +7 -5
  78. data/lib/arel_extensions/string_functions.rb +29 -59
  79. data/lib/arel_extensions/tasks.rb +6 -6
  80. data/lib/arel_extensions/version.rb +1 -1
  81. data/lib/arel_extensions/visitors/ibm_db.rb +31 -24
  82. data/lib/arel_extensions/visitors/mssql.rb +191 -422
  83. data/lib/arel_extensions/visitors/mysql.rb +212 -350
  84. data/lib/arel_extensions/visitors/oracle.rb +178 -220
  85. data/lib/arel_extensions/visitors/oracle12.rb +31 -18
  86. data/lib/arel_extensions/visitors/postgresql.rb +173 -256
  87. data/lib/arel_extensions/visitors/sqlite.rb +126 -140
  88. data/lib/arel_extensions/visitors/to_sql.rb +237 -298
  89. data/lib/arel_extensions/visitors.rb +62 -83
  90. data/lib/arel_extensions.rb +31 -224
  91. data/test/database.yml +7 -15
  92. data/test/helper.rb +18 -0
  93. data/test/real_db_test.rb +117 -120
  94. data/test/support/fake_record.rb +3 -9
  95. data/test/test_comparators.rb +17 -14
  96. data/test/visitors/test_bulk_insert_oracle.rb +11 -11
  97. data/test/visitors/test_bulk_insert_sqlite.rb +13 -12
  98. data/test/visitors/test_bulk_insert_to_sql.rb +13 -11
  99. data/test/visitors/test_oracle.rb +55 -55
  100. data/test/visitors/test_to_sql.rb +226 -419
  101. data/test/with_ar/all_agnostic_test.rb +366 -711
  102. data/test/with_ar/insert_agnostic_test.rb +21 -27
  103. data/test/with_ar/test_bulk_sqlite.rb +16 -17
  104. data/test/with_ar/test_math_sqlite.rb +26 -26
  105. data/test/with_ar/test_string_mysql.rb +33 -31
  106. data/test/with_ar/test_string_sqlite.rb +34 -30
  107. metadata +34 -43
  108. data/.github/workflows/publish.yml +0 -29
  109. data/.github/workflows/release.yml +0 -30
  110. data/.github/workflows/ruby.yml +0 -399
  111. data/CONTRIBUTING.md +0 -102
  112. data/NEWS.md +0 -89
  113. data/bin/build +0 -15
  114. data/bin/compose +0 -6
  115. data/bin/publish +0 -8
  116. data/dev/arelx.dockerfile +0 -44
  117. data/dev/compose.yaml +0 -71
  118. data/dev/postgres.dockerfile +0 -5
  119. data/dev/rbenv +0 -189
  120. data/gemfiles/rails4_2.gemfile +0 -38
  121. data/gemfiles/rails5.gemfile +0 -29
  122. data/gemfiles/rails6.gemfile +0 -33
  123. data/gemfiles/rails6_1.gemfile +0 -33
  124. data/gemfiles/rails7.gemfile +0 -33
  125. data/gemfiles/rails7_1.gemfile +0 -33
  126. data/gemfiles/rails7_2.gemfile +0 -33
  127. data/gemspecs/arel_extensions-v1.gemspec +0 -27
  128. data/gemspecs/arel_extensions-v2.gemspec +0 -27
  129. data/generate_gems.sh +0 -15
  130. data/lib/arel_extensions/aliases.rb +0 -14
  131. data/lib/arel_extensions/helpers.rb +0 -62
  132. data/lib/arel_extensions/nodes/aggregate_function.rb +0 -13
  133. data/lib/arel_extensions/nodes/formatted_date.rb +0 -42
  134. data/lib/arel_extensions/nodes/rollup.rb +0 -36
  135. data/lib/arel_extensions/nodes/select.rb +0 -10
  136. data/lib/arel_extensions/nodes/sum.rb +0 -7
  137. data/lib/arel_extensions/visitors/convert_format.rb +0 -37
  138. data/test/arelx_test_helper.rb +0 -74
  139. data/version_v1.rb +0 -3
  140. data/version_v2.rb +0 -3
@@ -1,29 +0,0 @@
1
- name: "Publish Gems"
2
- on:
3
- release:
4
- types: [published]
5
-
6
- jobs:
7
- publish_gems:
8
- name: Publish to Rubygems
9
- runs-on: ubuntu-latest
10
- steps:
11
- - uses: actions/checkout@v3
12
- - name: setup ruby 3.2
13
- uses: ruby/setup-ruby@v1
14
- with:
15
- ruby-version: 3.2
16
- - name: Fetch Github Release Asset
17
- uses: dsaltares/fetch-gh-release-asset@master
18
- with:
19
- file: "arel_extensions.*.gem"
20
- regex: true
21
- token: ${{ secrets.GITHUB_TOKEN }}
22
- - name: List gems
23
- run: ls -l *.gem
24
- - name: Release Gems
25
- uses: cadwallion/publish-rubygems-action@master
26
- env:
27
- GITHUB_TOKEN: ${{secrets.GITHUB_TOKEN}}
28
- RUBYGEMS_API_KEY: ${{secrets.RUBYGEMS_API_KEY}}
29
- RELEASE_COMMAND: bin/publish
@@ -1,30 +0,0 @@
1
- name: Release
2
- on:
3
- workflow_run:
4
- workflows: ["Build and Test"]
5
- branches: [master]
6
- types:
7
- - completed
8
-
9
- jobs:
10
- build_gems:
11
- name: Build Gemfiles
12
- runs-on: ubuntu-latest
13
- steps:
14
- - uses: actions/checkout@v3
15
- - name: setup ruby 3.2
16
- uses: ruby/setup-ruby@v1
17
- with:
18
- ruby-version: 3.2
19
- - name: build gems
20
- run: |
21
- bin/build
22
- - name: release
23
- uses: softprops/action-gh-release@v1
24
- with:
25
- tag_name: ${{ github.ref }}-${{ steps.vars.outputs.sha_short }}
26
- draft: true
27
- files: |
28
- ./arel_extensions-*.gem
29
- env:
30
- GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
@@ -1,399 +0,0 @@
1
- name: Build and Test
2
-
3
- # Ruby + Rails Compatibility Matrix from here:
4
- # https://www.fastruby.io/blog/ruby/rails/versions/compatibility-table.html
5
-
6
- on:
7
- push:
8
- branches:
9
- - master
10
- pull_request:
11
- branches:
12
- - master
13
-
14
- jobs:
15
- job_test_to_sql:
16
- name: test to_sql
17
- runs-on: ubuntu-latest
18
- strategy:
19
- fail-fast: false
20
- matrix:
21
- versions:
22
- [
23
- { ruby: "3.3", rails: 7_2, arelx: 2 },
24
- { ruby: "3.3", rails: 7_1, arelx: 2 },
25
- { ruby: "3.3", rails: 7, arelx: 2 },
26
- { ruby: "3.3", rails: 6_1, arelx: 2 },
27
- { ruby: "3.2", rails: 7_2, arelx: 2 },
28
- { ruby: "3.2", rails: 7_1, arelx: 2 },
29
- { ruby: "3.2", rails: 7, arelx: 2 },
30
- { ruby: "3.2", rails: 6, arelx: 2 },
31
- { ruby: "3.2", rails: 6_1, arelx: 2 },
32
- { ruby: "3.1", rails: 7_2, arelx: 2 },
33
- { ruby: "3.1", rails: 7_1, arelx: 2 },
34
- { ruby: "3.1", rails: 7, arelx: 2 },
35
- { ruby: "3.1", rails: 6_1, arelx: 2 },
36
- { ruby: "3.1", rails: 6, arelx: 2 },
37
- { ruby: "3.0", rails: 7_1, arelx: 2 },
38
- { ruby: "3.0", rails: 7, arelx: 2 },
39
- { ruby: "3.0", rails: 6_1, arelx: 2 },
40
- { ruby: "2.7", rails: 7_1, arelx: 2 },
41
- { ruby: "2.7", rails: 7, arelx: 2 },
42
- { ruby: "2.7", rails: 6_1, arelx: 2 },
43
- { ruby: "2.7", rails: 6, arelx: 2 },
44
- { ruby: "2.7", rails: 5_2, arelx: 1 },
45
- { ruby: "2.7", rails: 4_2, arelx: 1 },
46
- { ruby: "2.5", rails: 6_1, arelx: 2 },
47
- { ruby: "2.5", rails: 6, arelx: 2 },
48
- { ruby: "2.5", rails: 5_2, arelx: 1 },
49
- { ruby: "2.5", rails: 4_2, arelx: 1 },
50
- { ruby: jruby-9.2, rails: 6_1, arelx: 2 },
51
- { ruby: jruby-9.2, rails: 6, arelx: 2 },
52
- { ruby: jruby-9.2, rails: 5_2, arelx: 1 },
53
- { ruby: jruby-9.3, rails: 6_1, arelx: 2 },
54
- { ruby: jruby-9.3, rails: 6, arelx: 2 },
55
- { ruby: jruby-9.3, rails: 5_2, arelx: 1 },
56
- ]
57
- steps:
58
- - uses: actions/checkout@v2
59
- - name: Set up Ruby
60
- uses: ruby/setup-ruby@v1
61
- with:
62
- ruby-version: ${{ matrix.versions.ruby }}
63
- - name: Install FreeTDS
64
- run: |
65
- sudo apt-get update -q
66
- sudo apt-get install -y freetds-dev
67
- - name: Setup Gemfile
68
- run: |
69
- cp ./gemspecs/arel_extensions-v${{ matrix.versions.arelx }}.gemspec ./arel_extensions.gemspec
70
- cp ./version_v${{ matrix.versions.arelx }}.rb lib/arel_extensions/version.rb
71
- cp ./gemfiles/rails${{ matrix.versions.rails }}.gemfile ./Gemfile
72
- - name: bundle install
73
- run: |
74
- bundle config set gemfile ./gemfiles/rails${{ matrix.versions.rails }}.gemfile
75
- bundle install
76
- - name: Run test to_sql
77
- run: bundle exec rake test:to_sql
78
-
79
- job_test_sqlite:
80
- name: test sqlite
81
- runs-on: ubuntu-latest
82
- strategy:
83
- fail-fast: false
84
- matrix:
85
- versions:
86
- [
87
- { ruby: "3.3", rails: 7_2, arelx: 2 },
88
- { ruby: "3.3", rails: 7_1, arelx: 2 },
89
- { ruby: "3.3", rails: 7, arelx: 2 },
90
- { ruby: "3.3", rails: 6_1, arelx: 2 },
91
- { ruby: "3.2", rails: 7_2, arelx: 2 },
92
- { ruby: "3.2", rails: 7_1, arelx: 2 },
93
- { ruby: "3.2", rails: 7, arelx: 2 },
94
- { ruby: "3.2", rails: 6_1, arelx: 2 },
95
- { ruby: "3.2", rails: 6, arelx: 2 },
96
- { ruby: "3.1", rails: 7_2, arelx: 2 },
97
- { ruby: "3.1", rails: 7_1, arelx: 2 },
98
- { ruby: "3.1", rails: 7, arelx: 2 },
99
- { ruby: "3.1", rails: 6, arelx: 2 },
100
- { ruby: "3.1", rails: 6_1, arelx: 2 },
101
- { ruby: "3.0", rails: 7_1, arelx: 2 },
102
- { ruby: "3.0", rails: 7, arelx: 2 },
103
- { ruby: "3.0", rails: 6_1, arelx: 2 },
104
- { ruby: "2.7", rails: 7_1, arelx: 2 },
105
- { ruby: "2.7", rails: 7, arelx: 2 },
106
- { ruby: "2.7", rails: 6_1, arelx: 2 },
107
- { ruby: "2.7", rails: 6, arelx: 2 },
108
- { ruby: "2.7", rails: 5_2, arelx: 1 },
109
- { ruby: "2.7", rails: 4_2, arelx: 1 },
110
- { ruby: "2.5", rails: 6_1, arelx: 2 },
111
- { ruby: "2.5", rails: 6, arelx: 2 },
112
- { ruby: "2.5", rails: 5_2, arelx: 1 },
113
- { ruby: "2.5", rails: 4_2, arelx: 1 },
114
- { ruby: jruby-9.2, rails: 6_1, arelx: 2 },
115
- { ruby: jruby-9.2, rails: 6, arelx: 2 },
116
- { ruby: jruby-9.2, rails: 5_2, arelx: 1 },
117
- { ruby: jruby-9.2, rails: 4_2, arelx: 1 },
118
- { ruby: jruby-9.3, rails: 6_1, arelx: 2 },
119
- { ruby: jruby-9.3, rails: 6, arelx: 2 },
120
- { ruby: jruby-9.3, rails: 5_2, arelx: 1 },
121
- ]
122
- steps:
123
- - uses: actions/checkout@v2
124
- - name: Set up Ruby
125
- uses: ruby/setup-ruby@v1
126
- with:
127
- ruby-version: ${{ matrix.versions.ruby }}
128
- - name: Install FreeTDS
129
- run: |
130
- sudo apt-get update -q
131
- sudo apt-get install -y freetds-dev
132
- - name: Setup Gemfile
133
- run: |
134
- cp ./gemspecs/arel_extensions-v${{ matrix.versions.arelx }}.gemspec ./arel_extensions.gemspec
135
- cp ./version_v${{ matrix.versions.arelx }}.rb lib/arel_extensions/version.rb
136
- cp ./gemfiles/rails${{ matrix.versions.rails }}.gemfile ./Gemfile
137
- - name: bundle install
138
- run: |
139
- bundle config set gemfile ./gemfiles/rails${{ matrix.versions.rails }}.gemfile
140
- bundle install
141
- - name: Run test sqlite
142
- run: bundle exec rake test:sqlite
143
-
144
- job_test_postgres:
145
- name: test postgres
146
- runs-on: ubuntu-latest
147
- strategy:
148
- fail-fast: false
149
- matrix:
150
- versions: [
151
- { ruby: "3.3", rails: 7_2, arelx: 2 },
152
- { ruby: "3.3", rails: 7_1, arelx: 2 },
153
- { ruby: "3.3", rails: 7, arelx: 2 },
154
- { ruby: "3.3", rails: 6_1, arelx: 2 },
155
- { ruby: "3.2", rails: 7_2, arelx: 2 },
156
- { ruby: "3.2", rails: 7_1, arelx: 2 },
157
- { ruby: "3.2", rails: 7, arelx: 2 },
158
- { ruby: "3.2", rails: 6_1, arelx: 2 },
159
- # { ruby: "3.2", rails: 6, arelx: 2 }, # cannot test > undefined symbol: rb_tainted_str_new2
160
- { ruby: "3.1", rails: 7_2, arelx: 2 },
161
- { ruby: "3.1", rails: 7_1, arelx: 2 },
162
- { ruby: "3.1", rails: 7, arelx: 2 },
163
- { ruby: "3.1", rails: 6_1, arelx: 2 },
164
- { ruby: "3.1", rails: 6, arelx: 2 },
165
- { ruby: "3.0", rails: 7_1, arelx: 2 },
166
- { ruby: "3.0", rails: 7, arelx: 2 },
167
- { ruby: "3.0", rails: 6_1, arelx: 2 },
168
- { ruby: "2.7", rails: 7_1, arelx: 2 },
169
- { ruby: "2.7", rails: 7, arelx: 2 },
170
- { ruby: "2.7", rails: 6_1, arelx: 2 },
171
- { ruby: "2.7", rails: 6, arelx: 2 },
172
- { ruby: "2.7", rails: 5_2, arelx: 1 },
173
- { ruby: "2.7", rails: 4_2, arelx: 1 },
174
- { ruby: "2.5", rails: 6_1, arelx: 2 },
175
- { ruby: "2.5", rails: 6, arelx: 2 },
176
- { ruby: "2.5", rails: 5_2, arelx: 1 },
177
- { ruby: "2.5", rails: 4_2, arelx: 1 },
178
- { ruby: jruby-9.2, rails: 6_1, arelx: 2 },
179
- { ruby: jruby-9.2, rails: 6, arelx: 2 },
180
- { ruby: jruby-9.2, rails: 5_2, arelx: 1 },
181
- { ruby: jruby-9.2, rails: 4_2, arelx: 1 },
182
- { ruby: jruby-9.3, rails: 6_1, arelx: 2 },
183
- { ruby: jruby-9.3, rails: 6, arelx: 2 },
184
- { ruby: jruby-9.3, rails: 5_2, arelx: 1 },
185
- ]
186
- steps:
187
- - uses: actions/checkout@v2
188
- # PostgreSQL requires locales to be installed on the system to be able
189
- # to do time and currency conversions at runtime.
190
- #
191
- # That's why we're not launching it as a service; pre-built images
192
- # lack loaclization.
193
- #
194
- # After we install locales, we'll install PostgreSQL binaries and start
195
- # the service.
196
- - name: setup locale
197
- run: |
198
- sudo locale-gen fr_FR.utf8
199
- sudo update-locale
200
- - name: setup postgres 11
201
- run: |
202
- curl -fsSL https://www.postgresql.org/media/keys/ACCC4CF8.asc|sudo gpg --dearmor -o /etc/apt/trusted.gpg.d/postgresql.gpg
203
- echo "deb http://apt.postgresql.org/pub/repos/apt/ `lsb_release -cs`-pgdg main" | sudo tee /etc/apt/sources.list.d/pgdg.list
204
- sudo apt update
205
- sudo apt -y install postgresql-11
206
- sudo systemctl enable postgresql
207
- sudo systemctl start postgresql
208
- sudo su -c "psql -c \"alter user postgres with password 'secret'\"" postgres
209
- sudo su -c "createdb arelx_test" postgres
210
- - name: Set up Ruby
211
- uses: ruby/setup-ruby@v1
212
- with:
213
- ruby-version: ${{ matrix.versions.ruby }}
214
- - name: Install FreeTDS
215
- run: |
216
- sudo apt-get update -q
217
- sudo apt-get install -y freetds-dev
218
- - name: Setup Gemfile
219
- run: |
220
- cp ./gemspecs/arel_extensions-v${{ matrix.versions.arelx }}.gemspec ./arel_extensions.gemspec
221
- cp ./version_v${{ matrix.versions.arelx }}.rb lib/arel_extensions/version.rb
222
- cp ./gemfiles/rails${{ matrix.versions.rails }}.gemfile ./Gemfile
223
- - name: bundle install
224
- run: |
225
- bundle config set gemfile ./gemfiles/rails${{ matrix.versions.rails }}.gemfile
226
- bundle install
227
- - name: Run test Postgres
228
- env:
229
- PGHOST: localhost
230
- PGUSER: postgres
231
- run: bundle exec rake test:postgresql
232
-
233
- job_test_mysql:
234
- name: test mysql
235
- runs-on: ubuntu-latest
236
- strategy:
237
- fail-fast: false
238
- matrix:
239
- versions: [
240
- { ruby: "3.3", rails: 7_2, arelx: 2 },
241
- { ruby: "3.3", rails: 7_1, arelx: 2 },
242
- { ruby: "3.3", rails: 7, arelx: 2 },
243
- { ruby: "3.3", rails: 6_1, arelx: 2 },
244
- { ruby: "3.2", rails: 7_2, arelx: 2 },
245
- { ruby: "3.2", rails: 7_1, arelx: 2 },
246
- { ruby: "3.2", rails: 7, arelx: 2 },
247
- { ruby: "3.2", rails: 6_1, arelx: 2 },
248
- # { ruby: "3.2", rails: 6, arelx: 2 }, # cannot test > undefined symbol: rb_tainted_str_new2
249
- { ruby: "3.1", rails: 7_2, arelx: 2 },
250
- { ruby: "3.1", rails: 7_1, arelx: 2 },
251
- { ruby: "3.1", rails: 7, arelx: 2 },
252
- { ruby: "3.1", rails: 6_1, arelx: 2 },
253
- { ruby: "3.1", rails: 6, arelx: 2 },
254
- { ruby: "3.0", rails: 7_1, arelx: 2 },
255
- { ruby: "3.0", rails: 7, arelx: 2 },
256
- { ruby: "3.0", rails: 6_1, arelx: 2 },
257
- { ruby: "2.7", rails: 7_1, arelx: 2 },
258
- { ruby: "2.7", rails: 7, arelx: 2 },
259
- { ruby: "2.7", rails: 6_1, arelx: 2 },
260
- { ruby: "2.7", rails: 6, arelx: 2 },
261
- { ruby: "2.7", rails: 5_2, arelx: 1 },
262
- { ruby: "2.7", rails: 4_2, arelx: 1 },
263
- { ruby: "2.5", rails: 6_1, arelx: 2 },
264
- { ruby: "2.5", rails: 6, arelx: 2 },
265
- { ruby: "2.5", rails: 5_2, arelx: 1 },
266
- { ruby: "2.5", rails: 4_2, arelx: 1 },
267
- { ruby: jruby-9.2, rails: 6_1, arelx: 2 },
268
- { ruby: jruby-9.2, rails: 6, arelx: 2 },
269
- { ruby: jruby-9.2, rails: 5_2, arelx: 1 },
270
- { ruby: jruby-9.2, rails: 4_2, arelx: 1 },
271
- { ruby: jruby-9.3, rails: 6_1, arelx: 2 },
272
- { ruby: jruby-9.3, rails: 6, arelx: 2 },
273
- { ruby: jruby-9.3, rails: 5_2, arelx: 1 },
274
- ]
275
- services:
276
- mysql:
277
- image: mysql:5.7
278
- env:
279
- MYSQL_ALLOW_EMPTY_PASSWORD: true
280
- MYSQL_USERNAME: root
281
- MYSQL_DATABASE: arelx_test
282
- ports:
283
- - 3306:3306
284
- options: >-
285
- --health-cmd="mysqladmin ping"
286
- --health-interval=10s
287
- --health-timeout=5s
288
- --health-retries=3
289
- steps:
290
- - uses: actions/checkout@v2
291
- - name: Set up Ruby
292
- uses: ruby/setup-ruby@v1
293
- with:
294
- ruby-version: ${{ matrix.versions.ruby }}
295
- - name: Install FreeTDS
296
- run: |
297
- sudo apt-get update -q
298
- sudo apt-get install -y freetds-dev
299
- - name: Setup Gemfile
300
- run: |
301
- cp ./gemspecs/arel_extensions-v${{ matrix.versions.arelx }}.gemspec ./arel_extensions.gemspec
302
- cp ./version_v${{ matrix.versions.arelx }}.rb lib/arel_extensions/version.rb
303
- cp ./gemfiles/rails${{ matrix.versions.rails }}.gemfile ./Gemfile
304
- - name: bundle install
305
- run: |
306
- bundle config set gemfile ./gemfiles/rails${{ matrix.versions.rails }}.gemfile
307
- bundle install
308
- - name: Run test MySql
309
- env:
310
- DB_CONNECTION: mysql
311
- DB_HOST: 127.0.0.1
312
- DB_PORT: 3306
313
- DB_DATABASE: arelx_test
314
- DB_USERNAME: root
315
- run: bundle exec rake test:mysql
316
-
317
- job_test_mssql:
318
- name: test mssql on linux
319
- runs-on: ubuntu-latest
320
- strategy:
321
- fail-fast: false
322
- matrix:
323
- versions: [
324
- { ruby: "3.3", rails: 7_1, arelx: 2 },
325
- { ruby: "3.3", rails: 7, arelx: 2 },
326
- { ruby: "3.3", rails: 6_1, arelx: 2 },
327
- { ruby: "3.3", rails: 6, arelx: 2 },
328
- { ruby: "3.2", rails: 7_1, arelx: 2 },
329
- { ruby: "3.2", rails: 7, arelx: 2 },
330
- { ruby: "3.2", rails: 6_1, arelx: 2 },
331
- { ruby: "3.2", rails: 6, arelx: 2 },
332
- { ruby: "3.1", rails: 7_1, arelx: 2 },
333
- { ruby: "3.1", rails: 7, arelx: 2 },
334
- { ruby: "3.1", rails: 6_1, arelx: 2 },
335
- { ruby: "3.1", rails: 6, arelx: 2 },
336
- { ruby: "3.0", rails: 7, arelx: 2 },
337
- { ruby: "3.0", rails: 6_1, arelx: 2 },
338
- { ruby: "3.0", rails: 6, arelx: 2 },
339
- { ruby: "2.7", rails: 6_1, arelx: 2 },
340
- { ruby: "2.7", rails: 6, arelx: 2 },
341
- { ruby: "2.7", rails: 5_2, arelx: 1 },
342
- { ruby: "2.7", rails: 4_2, arelx: 1 },
343
- { ruby: "2.5", rails: 6_1, arelx: 2 },
344
- { ruby: "2.5", rails: 6, arelx: 2 },
345
- { ruby: "2.5", rails: 5_2, arelx: 1 },
346
- { ruby: "2.5", rails: 4_2, arelx: 1 },
347
- # {ruby: jruby-9.2, rails: 6_1, arelx: 2},
348
- # {ruby: jruby-9.2, rails: 6, arelx: 2},
349
- { ruby: jruby-9.2, rails: 5_2, arelx: 1 },
350
- { ruby: jruby-9.2, rails: 4_2, arelx: 1 },
351
- # See comments on 9.4 to understand why these are disabled for now.
352
- # {ruby: jruby-9.3, rails: 6_1, arelx: 2},
353
- # {ruby: jruby-9.3, rails: 6, arelx: 2},
354
- # {ruby: jruby-9.3, rails: 5_2, arelx: 1},
355
- { ruby: jruby-9.4, rails: 7_1, arelx: 2 },
356
- { ruby: jruby-9.4, rails: 7, arelx: 2 },
357
- #
358
- # 6 and 6.1 don't work because of a bug in the alt adapter
359
- # https://github.com/JesseChavez/activerecord-jdbc-adapter/issues/16
360
- # {ruby: jruby-9.4, rails: 6_1, arelx: 2},
361
- # {ruby: jruby-9.4, rails: 6, arelx: 2},
362
- #
363
- # < 5.2 don't work because of a deeper issue.
364
- # {ruby: jruby-9.4, rails: 5_2, arelx: 1},
365
- ]
366
- mssql: [2017, 2019]
367
- steps:
368
- - uses: actions/checkout@v2
369
- - name: Set up Ruby
370
- uses: ruby/setup-ruby@v1
371
- with:
372
- ruby-version: ${{ matrix.versions.ruby }}
373
- - name: Install FreeTDS
374
- run: |
375
- sudo apt-get update -q
376
- sudo apt-get install -y freetds-dev
377
- - name: Install MSSQL ${{ matrix.mssql }}
378
- uses: potatoqualitee/mssqlsuite@v1.5.1
379
- with:
380
- version: ${{ matrix.mssql }}
381
- install: sqlengine, sqlclient, sqlpackage, localdb
382
- sa-password: Password12!
383
- - name: Setup Gemfile
384
- run: |
385
- cp ./gemspecs/arel_extensions-v${{ matrix.versions.arelx }}.gemspec ./arel_extensions.gemspec
386
- cp ./version_v${{ matrix.versions.arelx }}.rb lib/arel_extensions/version.rb
387
- cp ./gemfiles/rails${{ matrix.versions.rails }}.gemfile ./Gemfile
388
- - name: bundle install
389
- run: |
390
- bundle config set gemfile ./gemfiles/rails${{ matrix.versions.rails }}.gemfile
391
- bundle install
392
- - name: Run test mssql [mri]
393
- if: ${{ !contains(matrix.versions.ruby, 'jruby') }}
394
- run: bundle exec rake test:mssql
395
- - name: Run test mssql [jruby]
396
- if: ${{ contains(matrix.versions.ruby, 'jruby') }}
397
- run: |
398
- curl -LO https://github.com/microsoft/mssql-jdbc/releases/download/v8.4.1/mssql-jdbc-8.4.1.jre11.jar
399
- CLASSPATH=".:mssql-jdbc-8.4.1.jre11.jar" bundle exec rake test:mssql
data/CONTRIBUTING.md DELETED
@@ -1,102 +0,0 @@
1
- # Contributing
2
-
3
- Your PRs are welcome.
4
-
5
- ## Local Development
6
-
7
- Let's say you want to develop/test for `ruby 2.7.5` and `rails 5.2`.
8
-
9
- You will need to fix your ruby version:
10
-
11
- ```bash
12
- rbenv install 2.7.5
13
- rbenv local 2.7.5
14
- ```
15
-
16
- Fix your gemfiles:
17
-
18
- ```bash
19
- bundle config set --local gemfile ./gemfiles/rails6.gemfile
20
- cp gemspecs/arel_extensions-v2.gemspec arel_extensions.gemspec
21
- ```
22
-
23
- Or by copying:
24
-
25
- ```bash
26
- cp gemfiles/gemfiles/rails6.gemfile Gemfiles
27
- cp gemspecs/arel_extensions-v2.gemspec arel_extensions.gemspec
28
- ```
29
-
30
- Install dependencies:
31
- ```bash
32
- bundle install
33
- ```
34
-
35
- > [!IMPORTANT]
36
- > Sometimes you might need to delete `vendor` dirs.
37
- > If you use `bundle config set --local gemfile`, it will be in `gemfiles/vendor`.
38
- > If you just `cp gemfiles/…`, it will be in `vendor`.
39
-
40
- Develop, then test:
41
-
42
- ```bash
43
- bundle exec rake test:to_sql
44
- ```
45
-
46
- Refer to the [Version Compatibility](#version-compatibility) section to correctly
47
- set your gemfile.
48
-
49
- ## Testing many DBs without installing them
50
-
51
- We provide a `docker compose` to set up some databases for testing:
52
-
53
- ```bash
54
- docker compose -f dev/compose.yaml up --exit-code-from arelx
55
- ```
56
-
57
- Or simply call `bin/compose`.
58
-
59
- The databases, versions of arelx, and versions of ruby are all read from the
60
- matrixes defined in `.github/workflow/ruby.yml`. To test a specific
61
- configuration, all you have to do is comment the versions you're not
62
- insterested in.
63
-
64
- > [!IMPORTANT]
65
- > This methods conflicts with the [Local development](#local-development) method.
66
- > If you find yourself jumping between both, make sure you delete `Gemfile.lock`
67
- > and `vendor/`.
68
-
69
- ### VSCode
70
-
71
- You can use the following `launch.json` to debug:
72
-
73
- ```json
74
- {
75
- "version": "0.2.0",
76
- "configurations": [
77
- {
78
- "type": "rdbg",
79
- "name": "Debug DB",
80
- "request": "launch",
81
- "cwd": "${workspaceRoot}",
82
- "script": "test/with_ar/all_agnostic_test.rb",
83
- "command": "bundle exec ruby -Ilib -Itest",
84
- "env": {
85
- "DB": "postgresql"
86
- },
87
- "useBundler": false,
88
- "askParameters": false
89
- },
90
- {
91
- "type": "rdbg",
92
- "name": "Debug to_sql",
93
- "request": "launch",
94
- "cwd": "${workspaceRoot}",
95
- "script": "test/visitors/test_to_sql.rb",
96
- "command": "bundle exec ruby -Ilib -Itest",
97
- "useBundler": false,
98
- "askParameters": false
99
- }
100
- ]
101
- }
102
- ```
data/NEWS.md DELETED
@@ -1,89 +0,0 @@
1
- # News
2
-
3
- ## [unreleased]
4
-
5
- ## Release v2.2.2/v1.4.2 (27-11-2024)
6
-
7
- - Fix deprecartion warnings for `==` and `!=`, showing the true location.
8
- - Always emit deprecartion warnings for `==` and `!=`.
9
-
10
- ## Release v2.2.1/v1.4.1 (08-11-2024)
11
-
12
- - Improved deprecartion warnings for `==` and `!=`, showing the location where they're called.
13
-
14
- ## Release v2.2.0/v1.4.0
15
-
16
- - MS SQL: restrict date-quoting to Arel <= 6 (Rails 4.2)
17
- - MS SQL: turn on warnings on requires only when gem is found
18
- - Rails: 7.2 support for mysql, postgres, and sqlite.
19
- - Attributes: deprecate `==` and `!=`. They're causing issues with
20
- `active_record`, and they're not sanitary.
21
-
22
- ## Release v2.1.11/v1.3.11
23
-
24
- - MS SQL: turn on warnings on requires only when necessary.
25
-
26
- ## Release v2.1.10/v1.3.10
27
-
28
- - MS SQL: add support for jruby 9.4 via [activerecord-jdbc-alt-adapter](https://rubygems.org/gems/activerecord-jdbc-alt-adapter/)
29
-
30
- ## Release v2.1.9/v1.3.9
31
-
32
- ### Bug Fixes
33
-
34
- - Postgres:
35
- - Datetime formatting in postgres now behaves like mysql: if the target
36
- timezone is a string, we automatically consider that you're trying to
37
- convert from `UTC`.
38
- - Datetime casting will now automatically ask for a
39
- `timestamp without timezone`, also aligning with the expected befavior
40
- in mysql. This also makes casting work better with timezone conversion,
41
- especially if you don't pass the timezone from which you're converting
42
- to.
43
- ```ruby
44
- scope
45
- .select(Arel.quoted('2022-02-01 10:42:00')
46
- .cast(:datetime)
47
- .format_date('%Y/%m/%d %H:%M:%S', 'Europe/Paris')
48
- .as('res'))
49
- ```
50
- Will produce:
51
- ```sql
52
- SELECT TO_CHAR(
53
- CAST('2022-02-01 10:42:00' AS timestamp without time zone) AT TIME ZONE 'UTC' AT TIME ZONE 'Europe/Paris',
54
- 'YYYY/MM/DD HH24:MI:SS'
55
- )
56
- AS "res"
57
- -- …
58
- ```
59
-
60
- ## Release v2.1.7/v1.3.7
61
-
62
- ### New Features
63
-
64
- - `o.format_date` as an alternative to `o.format`
65
- The actual behavior of `format` is inconsistent across DB vendors: in mysql we
66
- can format dates and numbers with it, and in the other ones we only format
67
- dates.
68
-
69
- We're planning on normalizing this behavior. We want `format` to "cleverly"
70
- format dates or numbers, and `format_date` / `format_number` to strictly
71
- format dates / numbers.
72
-
73
- The introduction of `format_date` is the first step in this direction.
74
-
75
- ## Release v2.1.6/v1.3.6
76
-
77
- ### Bug Fixes
78
-
79
- - This used to fail.
80
- ```
81
- Arel.when(a).then(b).format('%Y-%m-%d')
82
- ```
83
-
84
- ### New Features
85
-
86
- - `o.present`, a synonym for `o.not_blank`
87
- - `o.coalesce_blank(a, b, c)`
88
- - `o.if_present`, if the value is `null` or blank, then it returns `null`,
89
- otherwise, it returns the value. Inspired by rails' `presence`.
data/bin/build DELETED
@@ -1,15 +0,0 @@
1
- #! /usr/bin/env sh
2
- set -e
3
-
4
- # VERSION ~> 1
5
- echo "Packaging v1"
6
- cp ./version_v1.rb lib/arel_extensions/version.rb
7
- cp ./gemspecs/arel_extensions-v1.gemspec ./arel_extensions.gemspec
8
- gem build ./arel_extensions.gemspec
9
-
10
- # VERSION ~> 2
11
- echo "Packaging v2"
12
- cp ./version_v2.rb lib/arel_extensions/version.rb
13
- cp ./gemspecs/arel_extensions-v2.gemspec ./arel_extensions.gemspec
14
- gem build ./arel_extensions.gemspec
15
-
data/bin/compose DELETED
@@ -1,6 +0,0 @@
1
- #!/usr/bin/env bash
2
-
3
- IFS=$'\n\t'
4
- set -euo pipefail
5
-
6
- docker compose -f dev/compose.yaml up --exit-code-from arelx
data/bin/publish DELETED
@@ -1,8 +0,0 @@
1
- #! /usr/bin/env sh
2
- set -e
3
-
4
- find . -name "arel_extensions*.gem" | while read packaged_gem ; do
5
- echo "Publishing $packaged_gem"
6
- gem push "$packaged_gem"
7
- done
8
-