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

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

直接上代码。

主要是测 ram 、rom 、还有 剩余空间、目录管理、文件管理、分区边界测试,还是要结合自身的需求补充更多测试的。

比如没有做完整的读写正确性测试,擦除次数测试等等。

### 获取芯片的 ram 大小#def print_mem_free():    #import gc    #print('ram total : ' + str(gc.mem_free() / 1024) + ' kb')#print_mem_free()#gc.collect()#print_mem_free()# 文件系统测试import osFLASH = '/flash'## 获取 spiffs 映射的 flash 分区大小def print_flash_size(FLASH):    statvfs_fields = ['bsize', 'frsize', 'blocks', 'bfree', 'bavail', 'files', 'ffree', ]    info = dict(zip(statvfs_fields, os.statvfs(FLASH)))    # print(info)    print('flash total : ' + str(info['bsize'] * info['bfree'] / 1024) + ' kb')## 格式化 flash 文件系统def unit_test_fs_format():    os.flash_format()#unit_test_fs_format()#print_flash_size(FLASH)## 测试目录相关函数 不支持 # NotImplementedError: SPIFFS not supportdef 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)))#unit_test_fs_dir_mk_and_rm(FLASH)#print_flash_size(FLASH)## 测试文件相关函数 open stat remove renamedef 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))unit_test_fs_file_function(FLASH)print_flash_size(FLASH)## 测试文件的边界与重入 file write read closedef 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)) # 使用的是无 spiffs cache 的固件写入速度较慢。            #print(few.flush())            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()    ## 数据检查    ## 写入重入unit_test_fs_file(FLASH)print_flash_size(FLASH)

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

你可能感兴趣的文章
NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
查看>>
NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
查看>>
NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
查看>>
NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
查看>>
NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
查看>>
NIFI大数据进阶_NIFI监控功能实际操作_Summary查看系统和处理器运行情况_viewDataProvenance查看_---大数据之Nifi工作笔记0026
查看>>
NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
查看>>
NIFI大数据进阶_NIFI集群知识点_认识NIFI集群以及集群的组成部分---大数据之Nifi工作笔记0014
查看>>
NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
查看>>
NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
查看>>
NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
查看>>
NIFI大数据进阶_实时同步MySql的数据到Hive中去_可增量同步_实时监控MySql数据库变化_操作方法说明_01---大数据之Nifi工作笔记0033
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_说明操作步骤---大数据之Nifi工作笔记0028
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>