[lttng-dev] [LTTNG-TOOLS PATCH 2/2] Test the viewer detach command

Jérémie Galarneau jeremie.galarneau at efficios.com
Wed Jun 3 06:04:04 EDT 2015


On Thu, Mar 26, 2015 at 5:57 PM, Julien Desfossez <jdesfossez at efficios.com>
wrote:

> Signed-off-by: Julien Desfossez <jdesfossez at efficios.com>
> ---
>  tests/regression/tools/live/live_test.c | 64
> ++++++++++++++++++++++++++++++++-
>  1 file changed, 63 insertions(+), 1 deletion(-)
>
> diff --git a/tests/regression/tools/live/live_test.c
> b/tests/regression/tools/live/live_test.c
> index e30c391..8d718f6 100644
> --- a/tests/regression/tools/live/live_test.c
> +++ b/tests/regression/tools/live/live_test.c
> @@ -50,7 +50,7 @@
>  #define LIVE_TIMER 2000000
>
>  /* Number of TAP tests in this file */
> -#define NUM_TESTS 8
> +#define NUM_TESTS 11
>  #define mmap_size 524288
>
>  int ust_consumerd32_fd;
> @@ -257,6 +257,59 @@ error:
>         return ret;
>  }
>
> +int detach_viewer_session(uint64_t id)
> +{
> +       struct lttng_viewer_cmd cmd;
> +       struct lttng_viewer_detach_session_response resp;
> +       struct lttng_viewer_detach_session_request rq;
> +       int ret;
> +       ssize_t ret_len;
> +
> +       cmd.cmd = htobe32(LTTNG_VIEWER_DETACH_SESSION);
> +       cmd.data_size = sizeof(rq);
> +       cmd.cmd_version = 0;
> +
> +       memset(&rq, 0, sizeof(rq));
> +       rq.session_id = htobe64(id);
> +
> +       do {
> +               ret_len = send(control_sock, &cmd, sizeof(cmd), 0);
> +       } while (ret_len < 0 && errno == EINTR);
> +       if (ret_len < 0) {
> +               fprintf(stderr, "[error] Error sending cmd\n");
> +               ret = ret_len;
> +               goto error;
> +       }
> +       assert(ret_len == sizeof(cmd));
>

Please fail the test without asserting if this happens.


> +       do {
> +               ret = send(control_sock, &rq, sizeof(rq), 0);
> +       } while (ret < 0 && errno == EINTR);
> +       if (ret < 0) {
> +               fprintf(stderr, "Error sending attach request\n");
> +               goto error;
> +       }
> +
> +       do {
> +               ret_len = recv(control_sock, &resp, sizeof(resp), 0);
> +       } while (ret_len < 0 && errno == EINTR);
> +       if (ret_len < 0) {
> +               fprintf(stderr, "[error] Error receiving detach session
> reply\n");
> +               ret = ret_len;
> +               goto error;
> +       }
> +       assert(ret_len == sizeof(resp));
>

Same here.

Thanks!
Jérémie

+
> +       if (be32toh(resp.status) != LTTNG_VIEWER_DETACH_SESSION_OK) {
> +               fprintf(stderr, "[error] Error detaching viewer
> session\n");
> +               ret = -1;
> +               goto error;
> +       }
> +       ret = 0;
> +
> +error:
> +       return ret;
> +}
> +
>  int attach_session(int id)
>  {
>         struct lttng_viewer_cmd cmd;
> @@ -643,5 +696,14 @@ int main(int argc, char **argv)
>                         first_packet_stream_id, first_packet_offset,
>                         first_packet_len);
>
> +       ret = detach_viewer_session(session_id);
> +       ok(ret == 0, "Detach viewer session");
> +
> +       ret = list_sessions(&session_id);
> +       ok(ret > 0, "List sessions : %d session(s)", ret);
> +
> +       ret = attach_session(session_id);
> +       ok(ret > 0, "Attach to session, %d streams received", ret);
> +
>         return exit_status();
>  }
> --
> 1.9.1
>
>


-- 
Jérémie Galarneau
EfficiOS Inc.
http://www.efficios.com
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.lttng.org/pipermail/lttng-dev/attachments/20150603/a997804a/attachment-0001.html>


More information about the lttng-dev mailing list