-
Notifications
You must be signed in to change notification settings - Fork 192
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
[#2181] Redesign FileAPI to use original file name #2300
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.
Thank you very much for this PR and the detailed documentation @muyangye. I really appreciate!
I've left some minor remarks for improvements.
@dominikriemer Can you give the UI changes a review?
streampipes-rest/src/main/java/org/apache/streampipes/rest/impl/PipelineElementFile.java
Outdated
Show resolved
Hide resolved
streampipes-rest/src/main/java/org/apache/streampipes/rest/impl/PipelineElementFile.java
Outdated
Show resolved
Hide resolved
} | ||
|
||
@Override | ||
public void executeMigration() { |
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.
Would be great if you could add some documentation here about why this migration is necessary. So that we easily can relate this migration to it's purpose later on as well.
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.
That's a good suggestion! I'll add some documentation.
.../java/org/apache/streampipes/service/core/migrations/v095/DuplicateFilesRenameMigration.java
Outdated
Show resolved
Hide resolved
ui/src/app/files/dialog/file-rename/file-rename-dialog.component.html
Outdated
Show resolved
Hide resolved
…service/core/migrations/v095/DuplicateFilesRenameMigration.java Co-authored-by: Tim <50115603+bossenti@users.noreply.github.com>
…nt.html Co-authored-by: Tim <50115603+bossenti@users.noreply.github.com>
…l/PipelineElementFile.java Co-authored-by: Tim <50115603+bossenti@users.noreply.github.com>
…l/PipelineElementFile.java Co-authored-by: Tim <50115603+bossenti@users.noreply.github.com>
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.
Hi @muyangye,
thanks a lot for your PR. I think it's very good.
I have created another branch myself in which I have written a unit test for the DuplicateFilesRenameMigrationTest.executeMigration() method. I also refactored it a bit. What do you think? Do you think this iteration is an improvement? Link to branch
Hi @tenthe, thanks a lot for the refactoring! I think those code are much more self-explanatory! Thanks for the unit tests too. I didn’t write unit tests because this migration is a temporary solution. I’ll come up with unit tests for my next PR. Btw I still haven’t added a comment that Tim suggested and I will do that once I land (checking in for a flight right now) :) |
@bossenti @tenthe Sorry for the late reply. I am currently in China and I was trying to solve Github being blocked for the past 2 days and found no luck: |
Closing this PR as updated by #2356. |
* Serialize non-primitive types and store in Influx * extract RawFieldSerializer * rename test * delete old * temp * redesign file api * fix * Update streampipes-service-core/src/main/java/org/apache/streampipes/service/core/migrations/v095/DuplicateFilesRenameMigration.java Co-authored-by: Tim <50115603+bossenti@users.noreply.github.com> * Update ui/src/app/files/dialog/file-rename/file-rename-dialog.component.html Co-authored-by: Tim <50115603+bossenti@users.noreply.github.com> * Update streampipes-rest/src/main/java/org/apache/streampipes/rest/impl/PipelineElementFile.java Co-authored-by: Tim <50115603+bossenti@users.noreply.github.com> * Update streampipes-rest/src/main/java/org/apache/streampipes/rest/impl/PipelineElementFile.java Co-authored-by: Tim <50115603+bossenti@users.noreply.github.com> * refactor(#2181): Refactor DuplicateFilesRenameMigration * Add comment for migration * fix(#2356): Fix linting error * fix(#2356): Fix checkstyle proble --------- Co-authored-by: muyangye <muyangye@usc.edu> Co-authored-by: Tim <50115603+bossenti@users.noreply.github.com>
Purpose
Try to fix #2181
Remarks
PR introduces (a) breaking change(s): no
PR introduces (a) deprecation(s): no
After this change, if the users are trying to upload a file that already exists (same original file name ignoring case):
data:image/s3,"s3://crabby-images/bd370/bd370062d24aa45c29861a6f898893688b0ea6e0" alt="4b6edcdc19237ebba5a6203cb9a101d"
data:image/s3,"s3://crabby-images/3fc67/3fc676b7ddf79869852139e5d60994183a3f2670" alt="4e957bb66de0a8efb109f1836c35acc"
data:image/s3,"s3://crabby-images/b8aab/b8aab95af369690fca07035b13d651ba88391306" alt="baf592794791a090bfb4dc1667a54d3"
data:image/s3,"s3://crabby-images/615b0/615b0a9ec14eb50268885b779594c580ca476ae1" alt="9c2b2df4708ab6eff414548cdd208ac"
data:image/s3,"s3://crabby-images/98d8a/98d8a30511a4855f88953beb1c4bc130764536d7" alt="a16442acef371bad4aa52cf7dd69f2b"
data:image/s3,"s3://crabby-images/762e0/762e09ac943d6875a5e6a9b0f59deaa8f520dcd5" alt="00e5b52edead535d6fdd30cddd078b6"
data:image/s3,"s3://crabby-images/6837f/6837fe85df18b9524d1428559f49edaf438dbe86" alt="032a4cb01e70878cc8682d022a9f6aa"
data:image/s3,"s3://crabby-images/66ab2/66ab2d5ab884334069f36f5230aa5cd411a0b2d2" alt="10b2e6666174d825dbf869cf6b4b022"
They can upload just like before after rename:
Similarly, when users can upload multiple files and some of them already exist:
The dialog will keep appearing if even after rename, those files still exist:
As you may noticed, there are already some files with same name in the background. I created those files before this change to test migration. After the migration, they shall be renamed:
I have also created adapters using those files and verified they still work (as well as pipelines using those adapters):
I have not implemented E2E tests for this new feature because the discussion of #2181 is ongoing. If everyone is happy with this solution. I'll go ahead create an issue to implement the E2E tests.
I know the code is a little bit long. So TLDR, I have kept
internalFilename
andoriginalFilename
to avoid damages to other processes using current files. However, I added an endpoint/allFilenames
inPipelineElementFile
that fetches all currentoriginalFilename
s so that in the frontend I can check if some files users uploaded already exist and if so, let users rename those files. In addition, since before this change, there are probably some files with the same name, I have implemented aDuplicateFilesRenameMigration
to rename those files'originalFilename
.