-
Notifications
You must be signed in to change notification settings - Fork 588
HDDS-6646. Intermittent failure in TestOzoneFileSystem#testRenameToTrashEnabled #5217
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
Changes from 9 commits
2fcee89
d835998
b1b22f0
29e6c25
429eba3
768c833
fbc62a2
bfea174
02a62c5
183536e
900a80d
841d72d
fc4c53c
ec783f0
858e1ba
4ec8886
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | ||||
|---|---|---|---|---|---|---|
|
|
@@ -84,6 +84,7 @@ | |||||
| import java.util.Iterator; | ||||||
| import java.util.Set; | ||||||
| import java.util.TreeSet; | ||||||
| import java.util.concurrent.TimeoutException; | ||||||
|
|
||||||
| import static java.nio.charset.StandardCharsets.UTF_8; | ||||||
| import static org.apache.hadoop.fs.CommonConfigurationKeysPublic.FS_TRASH_CHECKPOINT_INTERVAL_KEY; | ||||||
|
|
@@ -228,7 +229,7 @@ public static void teardown() { | |||||
| public void cleanup() { | ||||||
| try { | ||||||
| deleteRootDir(); | ||||||
| } catch (IOException | InterruptedException ex) { | ||||||
| } catch (IOException | InterruptedException | TimeoutException ex) { | ||||||
| LOG.error("Failed to cleanup files.", ex); | ||||||
| fail("Failed to cleanup files."); | ||||||
| } | ||||||
|
|
@@ -795,18 +796,24 @@ public void testListStatusOnKeyNameContainDelimiter() throws Exception { | |||||
| * | ||||||
| * @throws IOException DB failure | ||||||
| */ | ||||||
| protected void deleteRootDir() throws IOException, InterruptedException { | ||||||
| protected void deleteRootDir() | ||||||
| throws IOException, InterruptedException, TimeoutException { | ||||||
| FileStatus[] fileStatuses = fs.listStatus(ROOT); | ||||||
|
|
||||||
| if (fileStatuses == null) { | ||||||
| return; | ||||||
| } | ||||||
| deleteRootRecursively(fileStatuses); | ||||||
| fileStatuses = fs.listStatus(ROOT); | ||||||
| if (fileStatuses != null) { | ||||||
| Assert.assertEquals( | ||||||
| "Delete root failed!", 0, fileStatuses.length); | ||||||
| } | ||||||
| GenericTestUtils.waitFor(() -> { | ||||||
| FileStatus[] fileStatus = new FileStatus[0]; | ||||||
| try { | ||||||
| fileStatus = fs.listStatus(ROOT); | ||||||
| return fileStatus != null && fileStatus.length == 0; | ||||||
| } catch (IOException e) { | ||||||
| Assert.assertFalse(fileStatus.length == 0); | ||||||
| return false; | ||||||
| } | ||||||
| }, 100, 500); | ||||||
| } | ||||||
|
|
||||||
| private static void deleteRootRecursively(FileStatus[] fileStatuses) | ||||||
|
|
@@ -1618,7 +1625,6 @@ public void testGetTrashRoots() throws IOException { | |||||
| * since fs.rename(src,dst,options) is enabled. | ||||||
| */ | ||||||
| @Test | ||||||
| @Flaky("HDDS-6646") | ||||||
| public void testRenameToTrashEnabled() throws Exception { | ||||||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Was the test removal intended? because earlier commit had fixed the test and description also says so.
Contributor
Author
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Yes @sadanand48 , as HDDS-6645 will be taking care of testTrash test case fix, so the only assertion which was different from
smengcl marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||
| // Create a file | ||||||
| String testKeyName = "testKey1"; | ||||||
|
|
@@ -1627,19 +1633,19 @@ public void testRenameToTrashEnabled() throws Exception { | |||||
| stream.write(1); | ||||||
| } | ||||||
|
|
||||||
| // Call moveToTrash. We can't call protected fs.rename() directly | ||||||
| trash.moveToTrash(path); | ||||||
|
|
||||||
| // Construct paths | ||||||
| String username = UserGroupInformation.getCurrentUser().getShortUserName(); | ||||||
| Path userTrash = new Path(TRASH_ROOT, username); | ||||||
| Path userTrashCurrent = new Path(userTrash, "Current"); | ||||||
| Path trashPath = new Path(userTrashCurrent, testKeyName); | ||||||
|
|
||||||
| // Trash Current directory should still have been created. | ||||||
| Assert.assertTrue(o3fs.exists(userTrashCurrent)); | ||||||
| // Check under trash, the key should be present | ||||||
| Assert.assertTrue(o3fs.exists(trashPath)); | ||||||
| Assert.assertFalse(o3fs.exists(userTrash)); | ||||||
| // Call moveToTrash. We can't call protected fs.rename() directly | ||||||
| trash.moveToTrash(path); | ||||||
| // We can safely assert only trash directory here. | ||||||
| // Asserting Current or checkpoint directory is not feasible here in this | ||||||
| // test due to independent TrashEmptier thread running in cluster and | ||||||
| // possible flakyness is hard to avoid unless we test this test case | ||||||
|
||||||
| // possible flakyness is hard to avoid unless we test this test case | |
| // possible flakiness is hard to avoid unless we test this test case |
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.
I'm not following this comment. What do you mean by will be tested as part of testTrash? This is testTrash test. Is there another testTrash? What am I missing?
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.
I'm not following this comment. What do you mean by
will be tested as part of testTrash? This istestTrashtest. Is there anothertestTrash? What am I missing?
As I mentioned, it will be handled as part of 6545 JIRA, and @sadanand48 will be working on it. Had a discussion on reason of flakiness and need to handle separately in testTrash
Uh oh!
There was an error while loading. Please reload this page.