-
Notifications
You must be signed in to change notification settings - Fork 414
/
Copy pathRELEASE-NOTES.txt
219 lines (182 loc) · 11.5 KB
/
RELEASE-NOTES.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
Release Notes -- Apache Jackrabbit Oak -- Version 1.78.0
Introduction
------------
Jackrabbit Oak is a scalable, high-performance hierarchical content
repository designed for use as the foundation of modern world-class
web sites and other demanding content applications.
Apache Jackrabbit Oak 1.78.0 is an incremental feature release based
on and compatible with earlier stable Jackrabbit Oak 1.x
releases. This release is considered stable and targeted for
production use.
While Oak 1.78.0 compiles and tests successfully on Java 17, Javadocs
generation fails on Java 17 (but works as expected on Java 11).
The Oak effort is a part of the Apache Jackrabbit project.
Apache Jackrabbit is a project of the Apache Software Foundation.
Changes in Oak 1.78.0
---------------------
Technical task
[OAK-11451] - Remove usage of Guava Iterables.concat()
[OAK-11462] - Remove usage of Guava Files.write()
[OAK-11481] - Remove (once more) usage of Guava Files.createTempDir()
[OAK-11482] - Remove usage of Guava Files.newReader
[OAK-11484] - Remove usage of Guava io.CountingInputStream
[OAK-11494] - Add Iterables.contains replacement in IterableUtils
[OAK-11495] - Add Iterables.size replacement in IteratorUtils
[OAK-11496] - Add Iterables.all replacement in IterableUtils
[OAK-11500] - Remove usage of Guava io.Closeable
[OAK-11503] - Add Iterables.isEmpty replacement in IterableUtils
[OAK-11507] - Use oak-commons IterableUtils instead of commons-collections4
[OAK-11513] - Add Iterables.toArray replacement in IterableUtils
[OAK-11514] - Remove usage of Guava Iterables.toArray
[OAK-11518] - Add Iterables.partition replacement in IterableUtils
[OAK-11519] - Remove usage of Guava Iterables.partition()
[OAK-11522] - Remove usage of Guava Iterables.filter()
[OAK-11523] - Add Iterables.filter replacement in IterableUtils
[OAK-11527] - Remove usage of Guava Iterables.transform()
[OAK-11528] - Add Iterables.transform replacement in IterableUtils
[OAK-11531] - Add Iterables.mergeSorted replacement in IterableUtils
[OAK-11532] - Remove usage of Guava Iterables.mergeSorted()
[OAK-11542] - Remove usage of Guava Iterables.elementsEqual()
[OAK-11543] - Add Iterables.elementsEqual replacement in IterableUtils
[OAK-11546] - Remove usage of Guava io.Closer
[OAK-11548] - Add Iterables.limit replacement in IterableUtils
[OAK-11549] - Remove usage of Guava Iterables.limit()
[OAK-11550] - Add Iterables.toString replacement in IterableUtils
[OAK-11551] - Remove usage of Guava Iterables.toString()
[OAK-11556] - Remove usage of Guava Iterables.getFirst()
[OAK-11557] - Remove usage of Guava Iterables.getOnlyElement()
[OAK-11558] - Remove usage of Guava Iterables.tryFind()
[OAK-11562] - Remove usage of Guava Iterables.addAll()
[OAK-11563] - Add Iterables.getFirst replacement in IterableUtils
[OAK-11565] - Add Iterables.get() replacement in IterableUtils
[OAK-11566] - Add Iterables.find() replacement in IterableUtils
[OAK-11567] - Remove usage of Guava Iterables.size (2)
[OAK-11571] - commons: add Closer class (similar to Guava Closer)
[OAK-11573] - Add Iterators.size replacement in IteratorUtils
[OAK-11574] - Remove usage of Guava Iterators.size()
[OAK-11575] - Add Iterables.getLast() replacement in IterableUtils
[OAK-11576] - Remove usage of Guava Iterables.get()
[OAK-11577] - Remove usage of Guava Iterables.find()
[OAK-11578] - Remove usage of Guava Iterables.getLast()
[OAK-11580] - Remove usage of Guava Iterables.skip()
[OAK-11581] - Remove usage of Guava Iterables.cycle
[OAK-11582] - Remove usage of Guava Iterables.removeAll
[OAK-11583] - Add Iterators.get replacement in IteratorUtils
[OAK-11584] - Add Iterators.getLast replacement in IteratorUtils
[OAK-11589] - Remove usage of Iterators.get
[OAK-11596] - Remove usage of Guava Iterables (imports)
[OAK-11602] - Remove usage of Guava ImmutableSet.copyOf [part 1]
[OAK-11605] - Remove usage of Guava ImmutableSet.copyOf [part 2]
[OAK-11615] - update groovy dependency to 3.0.24
Bug
[OAK-11461] - DocumentNodeStoreService - setClusterInvisible via config
[OAK-11464] - oak-it-osgi fails to load the bundle oak-search-elastic if the profile rdb-mysql is used for building and testing.
[OAK-11475] - oak-search-elastic: WordDelimiter filter does not convert type mappings
[OAK-11480] - AzureRepositoryLock: NPE in refresh thread
[OAK-11499] - Warning: Parameter 'aggregate' is unknown for plugin 'maven-javadoc-plugin:3.4.1:jar (default)'
[OAK-11508] - oak-search-elastic: is null / is not null queries should resolve the field name
[OAK-11529] - Infinite recursion in AstElement (for some platforms and configs)
[OAK-11536] - oak-search-elastic: synonym filter has to be lenient by default
[OAK-11539] - Flaky test: MembershipProviderTest#testGetMembershipInherited()
[OAK-11564] - oak-run FullGC leaves background threads running
[OAK-11570] - oak-run fullGC fullGcMaxAge default value is wrongly calculated
[OAK-11603] - Lucene 4.x fuzzy queries don't work in Elastic
[OAK-11619] - Fix flaky ConcurrentMultiplexingIndexWriterTest
[OAK-11624] - Elastic full-text queries are not lenient when the input value cannot be converted
[OAK-11630] - CommandTestUtils captureSystem* should normalize line feeds
Epic
[OAK-11047] - Oak should compile & test on Java 23
Story
[OAK-11444] - [full-gc] Save document id and empty properties names before deletion
[OAK-11491] - segment.azure.v12.enabled should be set to false after test execution is finished
New Feature
[OAK-8748] - Run performance tests and compare with baseline
Improvement
[OAK-11390] - Generate aggregate UT/IT reports
[OAK-11397] - Provide a way to get expanded names for items
[OAK-11435] - oak-search: the special baseline configuration may be removed from the pom.
[OAK-11436] - oak-segment-aws: the special baseline configuration may be removed from the pom.
[OAK-11454] - Explain query output: fix "synchronousPropertyCondition"
[OAK-11457] - Tree store sometimes contains bundled properties
[OAK-11460] - Allow configuring "index.mapping.total_fields.limit"
[OAK-11466] - Replace Fixed to Exponential retries in oak-segment-azure
[OAK-11468] - RDBDataSourceFactory unnecessarily loads the JDBC driver class explicitly.
[OAK-11469] - Speedup resolution of mount paths
[OAK-11472] - Improve error handling when index is missing Tika config
[OAK-11478] - Node store statistics: support the tree store
[OAK-11483] - Throttle log warn messages during indexing in Elastic
[OAK-11488] - Flaky test org.apache.jackrabbit.oak.plugins.document.VersionGarbageCollectorIT. testDeletedPropsAndUnmergedBCWithCollisionWithDryRunMode
[OAK-11489] - Flaky test org.apache.jackrabbit.oak.plugins.document.BranchCommitGCTest.unmergedAddsThenMergedAddThenUnmergedRemovesChildren
[OAK-11490] - VersionGarbageCollectorIT takes 1 hour to run
[OAK-11501] - Disable spotbugs
[OAK-11504] - Elasticsearch: support "flattened" fields
[OAK-11505] - Reduce object allocation in FullTextIndexEditor
[OAK-11509] - Incremental flat file store: reduce logging
[OAK-11510] - Performance improvements to IndexDefinition class
[OAK-11511] - Performance improvements to FullTextDocumentMaker class
[OAK-11515] - Fix indentation on indexing related classes
[OAK-11520] - Performance improvements to Aggregate class in indexing logic
[OAK-11526] - Reduce logging verbosity in IndexWriterPool when closing writers
[OAK-11530] - Elasticsearch: "field name cannot be an empty string" if fields start with a dot
[OAK-11533] - Reduce calls to PathUtils.concat() in FulltextIndexEditor
[OAK-11534] - Auto-merge indexes if string matches single-value array
[OAK-11538] - Cleanups and small performance improvements to CompositeEditor and CompositeIndexEditorProvider
[OAK-11544] - Flaky test PipelinedTreeStoreIT.createFFSCustomExcludePathsRegexNoRetryOnConnectionErrorRegexFiltering
[OAK-11547] - oak-search-elastic: upgrade Elasticsearch Java Client to 8.17.x
[OAK-11553] - Elastic: index name is swallowed in case of IllegalArgumentException
[OAK-11555] - Elastic: support dot and other special characters in property and function names
[OAK-11568] - Elastic: improved compatibility for analyzer definitions
[OAK-11597] - increase toxiproxy startup attempts
[OAK-11598] - Bump testcontainers to v1.20.6
[OAK-11606] - indexing-job: throttle messages warning about enqueuing delays in IndexWriterPool
[OAK-11610] - Clarify javadoc of o.a.j.api.security.user.UserManager.createUser() with respect to null passwords
[OAK-11613] - Expose ELASTIC_ENABLED metric
[OAK-11614] - ES StatisticalFacets: log search request on timeout
Test
[OAK-11252] - flaky BranchCommitGCTest.unmergedRemoveChild + unmergedAddsThenMergedAddsChildren
[OAK-11477] - Flaky test: DocumentDiscoveryLiteServiceIT.testLargeStartStopFiesta
Task
[OAK-11438] - indexing job: parallelize Lucene writer backend
[OAK-11456] - oak-solr-osgi embeds vulnerable Zookeeper 3.9.2
[OAK-11458] - Create IterableUtils in oak-commons
[OAK-11459] - Code cleanups on indexing related packages
[OAK-11506] - Update oak-segment-azure tools to use azure sdk v12 implementation
[OAK-11524] - Update oak-commons SetUtils to use commons-collections4 methods
[OAK-11541] - FullGC Mongo query has too broad scope
[OAK-11569] - Potential regression introduced with OAK-11287
[OAK-11586] - webapp: update Tomcat dependency to 9.0.102
[OAK-11594] - Converting existing indexes from a type to another leaves the async lane the same
[OAK-11595] - update Tomcat JDBC dependency to 9.0.102
[OAK-11611] - blob-cloud, segment: update netty version to 4.1.119
[OAK-11623] - Clean oak-segment-azure lib embedding and exporting
In addition to the above-mentioned changes, this release contains all
changes up to the previous release.
For more detailed information about all the changes in this and other
Oak releases, please see the Oak issue tracker at
https://issues.apache.org/jira/browse/OAK
Release Contents
----------------
This release consists of a single source archive packaged as a zip file.
The archive can be unpacked with the jar tool from your JDK installation.
See the README.md file for instructions on how to build this release.
The source archive is accompanied by SHA512 checksums and a
PGP signature that you can use to verify the authenticity of your
download. The public key used for the PGP signature can be found at
https://www.apache.org/dist/jackrabbit/KEYS.
About Apache Jackrabbit Oak
---------------------------
Jackrabbit Oak is a scalable, high-performance hierarchical content
repository designed for use as the foundation of modern world-class
web sites and other demanding content applications.
The Oak effort is a part of the Apache Jackrabbit project.
Apache Jackrabbit is a project of the Apache Software Foundation.
For more information, visit http://jackrabbit.apache.org/oak
About The Apache Software Foundation
------------------------------------
Established in 1999, The Apache Software Foundation provides organizational,
legal, and financial support for more than 140 freely-available,
collaboratively-developed Open Source projects. The pragmatic Apache License
enables individual and commercial users to easily deploy Apache software;
the Foundation's intellectual property framework limits the legal exposure
of its 3,800+ contributors.
For more information, visit http://www.apache.org/