Re: Python tests

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 8/24/22 22:40, Logan Gunthorpe wrote:
Hi,

On 2022-08-24 10:23, Coly Li wrote:


2022年8月24日 16:15,Lukasz Florczak <lukasz.florczak@xxxxxxxxxxxxxxx> 写道:

Hi Coly,
I want to write some mdadm tests for assemblation and incremental
regarding duplicated array names in config and I'd like to do it in
python. I've seen that some time ago[1] you said that you could try to
integrate the python tests framework into the mdadm ci. I was wondering
how is it going? Do you need any help with this subject?

Thanks,
Lukasz

[1] https://marc.info/?l=linux-raid&m=165277539509464&w=2

Hi Lukasz,

Now I just make some of the existed mdadm test scripts running, which are copied from upstream mdadm. There won’t be any conflict for the python testing code between you and me, because now I am just studying Python again and not do any useful thing yet.

As I said if no one works on the testing framework, I will do it, but it may take time. How about posting out the python code once you make it, then let’s put it into mdadm-test to test mdadm-CI, and improve whole things step by step.


I'm not sure if this is of use to anyone but we are very slowly growing
a testing framework written mostly in python. Its focused on raid5 at
the moment and still is a fairly sizable mess, but we've caught a lot of
bugs with it and continue to run it, clean it up and make improvements.

https://github.com/Eideticom/raid5-tests/

The 'md.py 'file provides a nice interface to setup an array based on
ram, loop or block devices and provides methods to degrade, recover or
grow the array. 'test3' does grow/degrade tests while running IO,
'test_all' runs all the tests with an array of different settings.

Feel free to use anything from it that you may find useful.

When developing 'md_monitor' (https://github.com/hreinecke/md_monitor) I've also created an extensive testsuite for it. The one thing which I found particularly painful is error handling once mdadm fails. It's really hard to figure out _what_ went wrong, and more often than not mdadm simply locked up on me (try to stall I/O on one component device while md is running and you are in a world of pain).

That's when I started to split mdadm into a library, as then we could have a python binding and the life would so much more fun.
So maybe I should resurrect that patchset.

Cheers,

Hannes
--
Dr. Hannes Reinecke                Kernel Storage Architect
hare@xxxxxxx                              +49 911 74053 688
SUSE Software Solutions GmbH, Maxfeldstr. 5, 90409 Nürnberg
HRB 36809 (AG Nürnberg), Geschäftsführer: Ivo Totev, Andrew
Myers, Andrew McDonald, Martje Boudien Moerman



[Index of Archives]     [Linux RAID Wiki]     [ATA RAID]     [Linux SCSI Target Infrastructure]     [Linux Block]     [Linux IDE]     [Linux SCSI]     [Linux Hams]     [Device Mapper]     [Device Mapper Cryptographics]     [Kernel]     [Linux Admin]     [Linux Net]     [GFS]     [RPM]     [git]     [Yosemite Forum]


  Powered by Linux