Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Test the Unix binding #539

Open
7 of 35 tasks
aantron opened this issue Jan 15, 2018 · 4 comments
Open
7 of 35 tasks

Test the Unix binding #539

aantron opened this issue Jan 15, 2018 · 4 comments
Milestone

Comments

@aantron
Copy link
Collaborator

aantron commented Jan 15, 2018

NOTE: this will be much easier to work on after mirage/alcotest#177 and #701.

This is a big issue for lots of PRs. Some parts of it could be quite easy, but on the whole I'd say it is of medium difficulty.

Some care should be taken to run the tests properly sandboxed, i.e. files created in temporary directories, etc. For that, the test framework in test/test.ml will probably have to be extended with new helper functions. I'm not sure how to sandbox DNS and some of the other APIs. We should probably discuss that.

Besides correct behavior, we need really thorough tests for various error conditions. The typical system call has man pages on multiple systems, listing the various ways the system call can fail. We want to trigger as many of those as possible. See section Help below for links to man pages.


The work

To make this manageable, I would break the work into chunks, based on the current order of functions in the various .mli files of the Unix binding. These aren't listed necessarily in the order they should be tested in. We generally want simple and obvious things tested first, and more complex things that depend on them tested later.

There are a few tests already written, but I included all the functions in the category list, so make sure to check before choosing a category. I'll try to keep the check boxes up to date.

If you'd like to work on one of these items, please leave a comment, to avoid duplication of effort :)

I've left Lwt_io for a separate issue.


Help

Cheating off Unix

Some of the easiest ways to test some bindings would be to do something with Lwt_unix (or other Lwt module), and check the result using stdlib's Unix.

man pages

Here are some man page references:

  • Linux
  • Mac It seems Apple has archived their man pages and made them difficult to discover, so you have to do a web search for each system call.
  • BSD
  • For Windows, it's probably best to look at what Win32 API Lwt actually calls in src/unix/windows_c/*, and then look the API up in MSDN. A search is probably the easiest way.

Skipping tests

Many Lwt APIs aren't implemented on Windows. Tests for them can be skipped like this:

test "lazy_undefined" ~only_if:(fun () -> not Sys.win32)

Coverage analysis

Coverage analysis is enabled for the OCaml code of the Unix binding – run make coverage, then open _coverage/index.html. This can help to see what still needs testing, though some of the code is visited unintentionally because other code depends on it. We don't have coverage analysis for C code at the moment. That could be its own PR, but maybe it's not necessary.

Of course, high coverage doesn't imply thorough testing. Only low coverage implies insufficient testing.


cc @cedlemo

@aantron aantron added the medium label Jan 15, 2018
@cedlemo
Copy link
Contributor

cedlemo commented May 5, 2018

@aantron I will work on Bigstrings.

@cedlemo cedlemo mentioned this issue Sep 8, 2018
@cedlemo
Copy link
Contributor

cedlemo commented Oct 13, 2018

Now I will work on "sleeping and timeout".

@cedlemo
Copy link
Contributor

cedlemo commented Oct 22, 2018

I continue with Lwt_throttle.

@anuragsoni
Copy link
Contributor

anuragsoni commented Mar 15, 2019

@aantron i've added some tests for unix Users (#673 )

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants