package async_smtp

  1. Overview
  2. Docs
Legend:
Page
Library
Module
Module type
Parameter
Class
Class type
Source

Source file retry_interval.ml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
module Stable = struct
  open Core.Core_stable
  module Time = Time_unix.Stable

  module V1 = struct
    type t = Time.Span.V2.t [@@deriving sexp]
  end

  module V2 = struct
    type t =
      { span : Time.Span.V2.t
      ; jitter : Time.Span.V2.t option
      }
    [@@deriving bin_io, sexp]

    let of_v1 span = { span; jitter = None }

    let t_of_sexp sexp =
      try t_of_sexp sexp with
      | _ -> of_v1 (V1.t_of_sexp sexp)
    ;;

    let%expect_test _ =
      print_endline [%bin_digest: t];
      [%expect {| 3b06ea6a0b45b9d183bb377f049d7b98 |}]
    ;;
  end
end

open! Core

type t = Stable.V2.t =
  { span : Time.Span.t
  ; jitter : Time.Span.t option
  }
[@@deriving compare, hash, sexp_of]

let create ?jitter span = { span; jitter }

let to_span { span; jitter } =
  match jitter with
  | None -> span
  | Some jitter ->
    let percent = Time.Span.to_sec jitter /. Time.Span.to_sec span |> Percent.of_mult in
    Time.Span.randomize span ~percent
;;

let%test_unit _ =
  let base = 10. in
  let jitter = 5. in
  let t = { span = Time.Span.of_sec base; jitter = Some (Time.Span.of_sec jitter) } in
  let rec test i =
    if i = 0
    then ()
    else (
      let span = to_span t in
      assert (Time.Span.( >= ) span (Time.Span.of_sec (base -. jitter)));
      assert (Time.Span.( <= ) span (Time.Span.of_sec (base +. jitter)));
      test (i - 1))
  in
  test 10
;;