-
Notifications
You must be signed in to change notification settings - Fork 674
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
SOLR-17548: Switch all public Java APIs from File to Path #2907
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Really excited about this refactoring! I made some comments, mostly around "hey, this is a nice chnage" or "hey, is this an opporutnity" versus "please change this" type comments.
One thing I am curious is how do we know all the conversions are done? I like the addition of the TODO to point out where more refactorings can be done. I guess I am wondering, once we have a lot of .toString()
or .toPath()
, how do we go back and remove the excess conversion loops? Also, i wonder if we need to add when this is done some forbiddenapi entries for file? I triggered the CI process... hopefully CI will run on all your other commits.
@@ -267,7 +267,7 @@ public void startMiniCluster(int nodeCount) { | |||
cluster = | |||
new MiniSolrCloudCluster.Builder(nodeCount, miniClusterBaseDir) | |||
.formatZkServer(false) | |||
.addConfig("conf", getFile("src/resources/configs/cloud-minimal/conf").toPath()) | |||
.addConfig("conf", getFile("src/resources/configs/cloud-minimal/conf")) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
love seeing the changed version is shorter and simpler than the original one!
public void setDataDir(File dataDir) { | ||
this.dataDir = dataDir; | ||
public void setDataDir(Path dataDir) { | ||
this.dataDir = dataDir.toFile(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
is this an example of where you felt changing things got out of hand? Otherwise, seems like if dataDir
was a Path, then no .toFile()
??
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah this one is setting dataDir
from an import existing in org.apache.zookeeper.server.quorum.QuorumPeerConfig
which is outside of Solr. If you see toFile()
it is most likely because it either got out of hand and I put TODO
to come back later or it wasn't possible to use Path
strictly
@@ -339,6 +339,8 @@ public String getDataHome(CoreDescriptor cd) throws IOException { | |||
|
|||
public void cleanupOldIndexDirectories( | |||
final String dataDirPath, final String currentIndexDirPath, boolean afterCoreReload) { | |||
|
|||
// TODO SOLR-8282 move to PATH |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Your stepwise logic is probably much better than a "lets change it all in one fell swoop!"
@@ -294,7 +294,7 @@ public void testDoFilesMode() throws IOException { | |||
postTool.recursive = 0; | |||
postTool.dryRun = true; | |||
postTool.solrUpdateUrl = URI.create("http://localhost:8983/solr/fake/update"); | |||
File dir = getFile("exampledocs"); | |||
File dir = getFile("exampledocs").toFile(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Since we just do a toString, maybe we can simplify this line???
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
matbe change postFiles to take in a list of paths?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Feels out of scope for now but agreed maybe we can simplify here. Unless you feel strongly about it, will add a TODO and I can do on a separate PR.
@@ -303,7 +303,7 @@ public void testDoFilesMode() throws IOException { | |||
public void testDetectingIfRecursionPossibleInFilesMode() throws IOException { | |||
PostTool postTool = new PostTool(); | |||
postTool.recursive = 1; // This is the default | |||
File dir = getFile("exampledocs"); | |||
File dir = getFile("exampledocs").toFile(); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
likewise, maybe we just make strings and avoid going thoruh the file type?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Or stay as a Path?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Agreed. I actually had done a lot of this work already across the repo but there were so many tests using File
and I tried to avoid the conversions or going through File
, the changes ended up over 800+ lines... So holding those code changes on my Fork for now.
For now, I was planning on keeping the conversions of toFile() and toPath() and we can move out of all of these conversions as best as possible on another PR. Should be easy with a search. I think here I was trying to get as many of the APIs return types and parameters off of File to keep in scope so it was reviewable.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This feels like maybe an opportunity to change from using either Strings and Files to just path and avoid some conversions??
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Read comment above
@@ -157,7 +157,7 @@ private static MiniSolrCloudCluster startCluster( | |||
|
|||
// new SolrCloudTestCase.Builder(1, baseDir).addConfig("conf", | |||
// getFile("configs/cloud-minimal/conf").toPath()).configure(); | |||
cluster.uploadConfigSet(getFile("configs/cloud-minimal/conf").toPath(), "conf"); | |||
cluster.uploadConfigSet(getFile("configs/cloud-minimal/conf"), "conf"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Love it!
@@ -44,7 +44,7 @@ public static void beforeClass() throws Exception { | |||
initCore( | |||
"solrconfig-script-updateprocessor.xml", | |||
"schema.xml", | |||
getFile("scripting/solr").getAbsolutePath()); | |||
getFile("scripting/solr").toAbsolutePath().toString()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe better to change initCore
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same reply as comment above.
@@ -41,7 +41,6 @@ public static void setupCluster() throws Exception { | |||
.addConfig( | |||
"conf", | |||
getFile("solrj") | |||
.toPath() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sweet!
Thanks for helping review @epugh! I found all imports of I found the File api was used so much in Tests, when I was doing conversions the number of lines changes became too much for this PR. I am holding those on my fork for now and hopefully I can maybe push that PR after this one. |
Sounds like you have a strong plan for moving forward @mlbiscoc and that's awesome. Do holler when you are ready for review and commit. |
This should be ready for review unless you want me to bring in those other changes but was going for that in a separate PR |
Cool... I'll leave it open for a few days to see what else crops up.. Ping me if we don't merge it by mid week! |
@@ -78,7 +77,7 @@ protected LockFactory createLockFactory(String rawLockType) throws IOException { | |||
|
|||
@Override | |||
public String normalize(String path) throws IOException { | |||
return super.normalize(new File(path).getCanonicalPath()); | |||
return super.normalize(Path.of(path).toAbsolutePath().toString()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
File.getCanonicalPath is not identical to Path.toAbsolutePath. It requires adding normalize().
private boolean copyTmpTlogFiles2Tlog(Path tmpTlogDir) { | ||
Path tlogDir = | ||
FileSystems.getDefault().getPath(solrCore.getUpdateHandler().getUpdateLog().getTlogDir()); | ||
Path backupTlogDir = | ||
FileSystems.getDefault() | ||
.getPath(tlogDir.getParent().toAbsolutePath().toString(), tmpTlogDir.getName()); | ||
.getPath( | ||
tlogDir.getParent().toAbsolutePath().toString(), | ||
tmpTlogDir.getFileName().toString()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This looks more complicated than it needs to be. It's highly unusual for anyone to need to refer to FileSystems. Look at the implementation of Path.of(...)
which proves we can just use Path.of here.
But hey, copyTmpTlogFiles2Tlog isn't used at all so let's just delete it!
log.info("File-based storage initialized to use dir: {}", storageDir); | ||
} | ||
|
||
@Override | ||
public boolean exists(String storedResourceId) throws IOException { | ||
return (new File(storageDir, storedResourceId)).exists(); | ||
return (Files.exists(Path.of(storageDir, storedResourceId))); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
there's a needless parenthesis here
@@ -108,7 +109,7 @@ public Lookup create(NamedList<?> params, SolrCore core) { | |||
|
|||
try { | |||
return new AnalyzingInfixSuggester( | |||
FSDirectory.open(new File(indexPath).toPath()), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wow that line of code was sad.
final String prefix = TLOG_NAME + '.'; | ||
String[] names = directory.list((dir, name) -> name.startsWith(prefix)); | ||
String[] names = directory.toFile().list((dir, name) -> name.startsWith(prefix)); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please don't call toFile
File testHome = createTempDir().toFile(); | ||
FileUtils.copyDirectory(getFile("analysis-extras/solr"), testHome); | ||
FileUtils.copyDirectory(getFile("analysis-extras/solr").toFile(), testHome); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Skip File conversion and use PathUtils.copyDirectory
File testHome = createTempDir().toFile(); | ||
FileUtils.copyDirectory(getFile("analysis-extras/solr"), testHome); | ||
FileUtils.copyDirectory(getFile("analysis-extras/solr").toFile(), testHome); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
(same as my last comment)
File testHome = createTempDir().toFile(); | ||
FileUtils.copyDirectory(getFile("analysis-extras/solr"), testHome); | ||
FileUtils.copyDirectory(getFile("analysis-extras/solr").toFile(), testHome); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
(same)
File testHome = createTempDir().toFile(); | ||
FileUtils.copyDirectory(getFile("clustering/solr"), testHome); | ||
FileUtils.copyDirectory(getFile("clustering/solr").toFile(), testHome); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
same
upload.setUploadFile(tmpFile, "application/zip"); | ||
upload.setUploadFile(tmpFile.toPath(), "application/zip"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
simply declare tmpFile as Path without conversion and maybe no further changes
@dsmiley Addressed your comments above. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nice!
@@ -55,16 +54,16 @@ public static void copyFile(File src, File destination) throws IOException { | |||
* @param fullFile the File to be synced to disk | |||
* @throws IOException if the file could not be synced | |||
*/ | |||
public static void sync(File fullFile) throws IOException { | |||
if (fullFile == null || !fullFile.exists()) | |||
public static void sync(Path fullFile) throws IOException { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
now remove the method
Oh duh... Removed! |
https://issues.apache.org/jira/browse/SOLR-17548
Description
Move from
File
to the more modernjava.nio.file.Path
Solution
Tried to find all of the public constructors/methods where
File
is being used or returned as a type and do it's conversion toPath
instead. If the conversion was simple, also changed theFile
methods being used to its equivalentPath
methods to stop using thetoFile()
call.There were some places where it required a much larger rework which felt at of scope of this already large number of changes. For those I placed a
// TODO SOLR-8282 move to PATH
Tests
Modified most uses of
File
toPath
and many of the changes revolve around me removing thetoPath()
.Checklist
Please review the following and check all that apply:
main
branch../gradlew check
.