博客
关于我
写了一下 micropython 的文件系统单元测试
阅读量:432 次
发布时间:2019-03-06

本文共 2732 字,大约阅读时间需要 9 分钟。

硬件测试与文件系统验证

为了确保系统的稳定性和功能性,我们需要对硬件和文件系统进行全面的测试。以下是主要测试内容和步骤说明。

1. 获取芯片的内存大小

我们可以通过以下方法获取芯片的内存大小:

def print_mem_free():    import gc    print('ram total : ' + str(gc.mem_free() // 1024) + ' kb')    gc.collect()

运行上述代码可以获取当前的内存使用情况。

2. 文件系统测试

首先,我们需要验证文件系统的总大小:

import osFLASH = '/flash'def print_flash_size(FLASH):    statvfs_fields = ['bsize', 'frsize', 'blocks', 'bfree', 'bavail', 'files', 'ffree']    info = dict(zip(statvfs_fields, os.statvfs(FLASH)))    print('flash total : ' + str(info['bsize'] * info['bfree'] // 1024) + ' kb')

运行 print_flash_size(FLASH) 可以查看闪存的总大小。

3. 格式化文件系统

为了确保文件系统的格式化过程正确,我们可以执行以下验证:

def unit_test_fs_format():    os.flash_format()

运行上述函数后,重新调用 print_flash_size(FLASH) 查看文件系统的格式化结果。

4. 目录管理测试

我们需要验证目录操作的正确性:

def unit_test_fs_dir_mk_and_rm(FLASH):    assert(0 == len(os.listdir(FLASH)))    os.mkdir('test')    os.rmdir('test')    assert(0 == len(os.listdir(FLASH)))

运行该函数后,检查目录操作是否成功完成。

5. 文件操作测试

文件的读写和重命名操作需要进行详细验证:

def unit_test_fs_file_function(FLASH):    name, info = 't.txt', b'0123456789ABCDEF'    # 创建文件    few = open(name, "wb")    few.write(info)    #assert(os.stat(name)[6] == 0)  # 可以在 menuconfig 中取消 cache 机制    print(os.stat(name))    # 文件应该存在了,但内容还未写入,此时则证明有 write cache 工作。    assert(name in os.listdir(FLASH))    few.close()    # 检查文件是否存在,且文件大小为 len(info) 。    assert(os.stat(name)[6] == len(info))    # 确认文件读取    fer = open(name, "rb")    assert(fer.read() == info)    fer.close()    # 确认 rename 工作    tmp = 'rename.txt'    os.rename(name, tmp)    assert(tmp in os.listdir(FLASH))    os.rename(tmp, name)    assert(name in os.listdir(FLASH))    os.remove(name)    assert(name not in os.listdir(FLASH))

运行该函数后,逐一验证文件操作是否正确完成。

6. 文件边界与重入测试

为了确保文件操作的稳定性,我们需要进行以下测试:

def unit_test_fs_file(FLASH):    name, info = 't.txt', b'0123456789ABCDEF'    if (name in os.listdir(FLASH)):        os.remove(name)    few = open(name, "wb")    few.write(info)    few.close()    # 测试内容    few = open(name, "ab")    assert(few.read() == info)    few.write(name)    few.close()    few = open(name, "ab")    assert(few.read() == info + name)    few.close()    if (name in os.listdir(FLASH)):        os.remove(name)    # 边界检查    import time, gc    count, tm = 0, time.ticks_ms()    info = info * 10240    print(len(info), time.ticks_diff(time.ticks_ms(), tm))    gc.collect()    try:        few = open(name, "wb")        while True:            print(few.write(info))            count = count + 1            print(count * len(info))            print_flash_size(FLASH)        few.close()    except Exception as e:        print(e)    finally:        print(count * len(info), time.ticks_diff(time.ticks_ms(), tm))        print_flash_size(FLASH)        few.close()    # 数据检查    # 写入重入

运行该函数后,逐一验证文件边界和重入操作是否正确完成。

转载地址:http://inbyz.baihongyu.com/

你可能感兴趣的文章
numpy数组索引-ChatGPT4o作答
查看>>
NUMPY矢量化np.prod不能构造具有超过32个操作数的ufunc
查看>>
Numpy矩阵与通用函数
查看>>
numpy绘制热力图
查看>>
numpy转PIL 报错TypeError: Cannot handle this data type
查看>>
Numpy闯关100题,我闯了95关,你呢?
查看>>
nump模块
查看>>
Nutch + solr 这个配合不错哦
查看>>
NuttX 构建系统
查看>>
NutUI:京东风格的轻量级 Vue 组件库
查看>>
NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
查看>>
NutzWk 5.1.5 发布,Java 微服务分布式开发框架
查看>>
NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
查看>>
Nuxt Time 使用指南
查看>>
NuxtJS 接口转发详解:Nitro 的用法与注意事项
查看>>
NVDIMM原理与应用之四:基于pstore 和 ramoops保存Kernel panic日志
查看>>
NVelocity标签使用详解
查看>>
NVelocity标签设置缓存的解决方案
查看>>
Nvidia Cudatoolkit 与 Conda Cudatoolkit
查看>>
NVIDIA GPU 的状态信息输出,由 `nvidia-smi` 命令生成
查看>>