Blame tests/nvme_test_io.py

Packit Service b7b338
# Copyright (c) 2015-2016 Western Digital Corporation or its affiliates.
Packit Service b7b338
#
Packit Service b7b338
# This program is free software; you can redistribute it and/or
Packit Service b7b338
# modify it under the terms of the GNU General Public License
Packit Service b7b338
# as published by the Free Software Foundation; either version 2
Packit Service b7b338
# of the License, or (at your option) any later version.
Packit Service b7b338
#
Packit Service b7b338
# This program is distributed in the hope that it will be useful,
Packit Service b7b338
# but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service b7b338
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service b7b338
# GNU General Public License for more details.
Packit Service b7b338
#
Packit Service b7b338
# You should have received a copy of the GNU General Public License
Packit Service b7b338
# along with this program; if not, write to the Free Software
Packit Service b7b338
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
Packit Service b7b338
# MA  02110-1301, USA.
Packit Service b7b338
#
Packit Service b7b338
#   Author: Chaitanya Kulkarni <chaitanya.kulkarni@hgst.com>
Packit Service b7b338
#
Packit Service b7b338
""" Inherit TestNVMeIO for nvme read/write operations """
Packit Service b7b338
Packit Service b7b338
import os
Packit Service b7b338
from nose import tools
Packit Service b7b338
from nvme_test import TestNVMe
Packit Service b7b338
Packit Service b7b338
Packit Service b7b338
class TestNVMeIO(TestNVMe):
Packit Service b7b338
Packit Service b7b338
    """
Packit Service b7b338
    Variable and Methods required to perform nvme read/write.
Packit Service b7b338
Packit Service b7b338
        - Attributes:
Packit Service b7b338
              - data_size : data size to perform IO.
Packit Service b7b338
              - start_block : starting block of to perform IO.
Packit Service b7b338
              - block_count : Number of blocks to use in IO.
Packit Service b7b338
              - write_file : data file to use in nvme write command.
Packit Service b7b338
              - read_file : data file to use in nvme read command.
Packit Service b7b338
    """
Packit Service b7b338
Packit Service b7b338
    def __init__(self):
Packit Service b7b338
        """ Pre Section for TestNVMeIO """
Packit Service b7b338
        TestNVMe.__init__(self)
Packit Service b7b338
        # common code used in various testcases.
Packit Service b7b338
        self.data_size = 512
Packit Service b7b338
        self.start_block = 0
Packit Service b7b338
        self.block_count = 0
Packit Service b7b338
        self.write_file = "write_file.txt"
Packit Service b7b338
        self.read_file = "read_file.txt"
Packit Service b7b338
Packit Service b7b338
    def __del__(self):
Packit Service b7b338
        """ Post Section for TestNVMeIO """
Packit Service b7b338
        TestNVMe.__del__(self)
Packit Service b7b338
Packit Service b7b338
    @tools.nottest
Packit Service b7b338
    def create_data_file(self, pathname, data_size, pattern):
Packit Service b7b338
        """ Creates data file with specific pattern
Packit Service b7b338
            - Args:
Packit Service b7b338
                - pathname : data file path name.
Packit Service b7b338
                - data_size : total size of the data.
Packit Service b7b338
                - pattern : data pattern to create file.
Packit Service b7b338
            - Returns:
Packit Service b7b338
            None
Packit Service b7b338
        """
Packit Service b7b338
        pattern_len = len(pattern)
Packit Service b7b338
        data_file = open(pathname, "w")
Packit Service b7b338
        for i in range(0, data_size):
Packit Service b7b338
            data_file.write(pattern[i % pattern_len])
Packit Service b7b338
        data_file.flush()
Packit Service b7b338
        os.fsync(data_file.fileno())
Packit Service b7b338
        data_file.close()
Packit Service b7b338
Packit Service b7b338
    @tools.nottest
Packit Service b7b338
    def nvme_write(self):
Packit Service b7b338
        """ Wrapper for nvme write operation
Packit Service b7b338
            - Args:
Packit Service b7b338
                - None
Packit Service b7b338
            - Returns:
Packit Service b7b338
                - return code for nvme write command.
Packit Service b7b338
        """
Packit Service b7b338
        write_cmd = "nvme write " + self.ns1 + " --start-block=" + \
Packit Service b7b338
                    str(self.start_block) + " --block-count=" + \
Packit Service b7b338
                    str(self.block_count) + " --data-size=" + \
Packit Service b7b338
                    str(self.data_size) + " --data=" + self.write_file
Packit Service b7b338
        return self.exec_cmd(write_cmd)
Packit Service b7b338
Packit Service b7b338
    @tools.nottest
Packit Service b7b338
    def nvme_read(self):
Packit Service b7b338
        """ Wrapper for nvme read operation
Packit Service b7b338
            - Args:
Packit Service b7b338
                - None
Packit Service b7b338
            - Returns:
Packit Service b7b338
                - return code for nvme read command.
Packit Service b7b338
        """
Packit Service b7b338
        read_cmd = "nvme read " + self.ns1 + " --start-block=" + \
Packit Service b7b338
                   str(self.start_block) + " --block-count=" + \
Packit Service b7b338
                   str(self.block_count) + " --data-size=" + \
Packit Service b7b338
                   str(self.data_size) + " --data=" + self.read_file
Packit Service b7b338
        print(read_cmd)
Packit Service b7b338
        return self.exec_cmd(read_cmd)