-
Notifications
You must be signed in to change notification settings - Fork 80
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #8577 from romayalon/romy-file-writer
NSFS | Replace ChunkFS with FileWriter
- Loading branch information
Showing
9 changed files
with
252 additions
and
194 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,69 @@ | ||
/* Copyright (C) 2020 NooBaa */ | ||
/* eslint-disable no-invalid-this */ | ||
'use strict'; | ||
|
||
const mocha = require('mocha'); | ||
const config = require('../../../config'); | ||
const file_writer_hashing = require('../../tools/file_writer_hashing'); | ||
const orig_iov_max = config.NSFS_DEFAULT_IOV_MAX; | ||
|
||
// on iov_max small tests we need to use smaller amount of parts and chunks to ensure that the test will finish | ||
// in a reasonable period of time because we will flush max 1/2 buffers at a time. | ||
const small_iov_num_parts = 20; | ||
|
||
|
||
mocha.describe('FileWriter', function() { | ||
const RUN_TIMEOUT = 10 * 60 * 1000; | ||
|
||
mocha.afterEach(function() { | ||
config.NSFS_DEFAULT_IOV_MAX = orig_iov_max; | ||
}); | ||
|
||
mocha.it('Concurrent FileWriter with hash target', async function() { | ||
const self = this; | ||
self.timeout(RUN_TIMEOUT); | ||
await file_writer_hashing.hash_target(); | ||
}); | ||
|
||
mocha.it('Concurrent FileWriter with file target', async function() { | ||
const self = this; | ||
self.timeout(RUN_TIMEOUT); | ||
await file_writer_hashing.file_target(); | ||
}); | ||
|
||
mocha.it('Concurrent FileWriter with hash target - iov_max=1', async function() { | ||
const self = this; | ||
self.timeout(RUN_TIMEOUT); | ||
await file_writer_hashing.hash_target(undefined, small_iov_num_parts, 1); | ||
}); | ||
|
||
mocha.it('Concurrent FileWriter with file target - iov_max=1', async function() { | ||
const self = this; | ||
self.timeout(RUN_TIMEOUT); | ||
await file_writer_hashing.file_target(undefined, small_iov_num_parts, 1); | ||
}); | ||
|
||
mocha.it('Concurrent FileWriter with hash target - iov_max=2', async function() { | ||
const self = this; | ||
self.timeout(RUN_TIMEOUT); | ||
await file_writer_hashing.hash_target(undefined, small_iov_num_parts, 2); | ||
}); | ||
|
||
mocha.it('Concurrent FileWriter with file target - iov_max=2', async function() { | ||
const self = this; | ||
self.timeout(RUN_TIMEOUT); | ||
await file_writer_hashing.file_target(undefined, small_iov_num_parts, 2); | ||
}); | ||
|
||
mocha.it('Concurrent FileWriter with file target - produce num_chunks > 1024 && total_chunks_size < config.NSFS_BUF_SIZE_L', async function() { | ||
const self = this; | ||
self.timeout(RUN_TIMEOUT); | ||
// The goal of this test is to produce num_chunks > 1024 && total_chunks_size < config.NSFS_BUF_SIZE_L | ||
// so we will flush buffers because of reaching max num of buffers and not because we reached the max NSFS buf size | ||
// chunk size = 100, num_chunks = (10 * 1024 * 1024)/100 < 104587, 104587 = num_chunks > 1024 | ||
// chunk size = 100, total_chunks_size after having 1024 chunks is = 100 * 1024 < config.NSFS_BUF_SIZE_L | ||
const chunk_size = 100; | ||
const parts_s = 50; | ||
await file_writer_hashing.file_target(chunk_size, parts_s); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.