package octez-libs
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>
A package that contains multiple base libraries used by the Octez suite
Install
dune-project
Dependency
Authors
Maintainers
Sources
tezos-octez-v20.1.tag.bz2
sha256=ddfb5076eeb0b32ac21c1eed44e8fc86a6743ef18ab23fff02d36e365bb73d61
sha512=d22a827df5146e0aa274df48bc2150b098177ff7e5eab52c6109e867eb0a1f0ec63e6bfbb0e3645a6c2112de3877c91a17df32ccbff301891ce4ba630c997a65
doc/src/octez-libs.tezt-wrapper/tezt_wrapper.ml.html
Source file tezt_wrapper.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 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185
(*****************************************************************************) (* *) (* SPDX-License-Identifier: MIT *) (* SPDX-FileCopyrightText: 2023 Nomadic Labs <contact@nomadic-labs.com> *) (* *) (*****************************************************************************) include Tezt open Base type error_mode = Ignore | Warn | Fail let error_mode_for_missing_use = ref Fail let error_mode_for_useless_use = ref Warn let error_mode_for_non_existing_use = ref Fail module Uses = struct type t = {tag : string; path : string} (* Filled by [make] and read by [lookup]. *) let known_paths : t String_map.t ref = ref String_map.empty let canonicalize_path path = String.split_on_char '/' path |> List.filter (function "" | "." -> false | _ -> true) |> String.concat "/" let add_to_known_paths path uses = let path = canonicalize_path path in known_paths := String_map.update path (function None -> Some uses | Some _ as x -> x) !known_paths let make ~tag ~path = let uses = {tag; path} in add_to_known_paths path uses ; uses let path_handler : (t -> unit) ref = ref (fun _ -> ()) let path uses = !path_handler uses ; uses.path let tag uses = uses.tag let lookup path = String_map.find_opt (canonicalize_path path) !known_paths let octez_node = make ~tag:"node" ~path:"./octez-node" let octez_client = make ~tag:"client" ~path:"./octez-client" let octez_admin_client = make ~tag:"admin_client" ~path:"./octez-admin-client" let register_meta_test () = Regression.register ~__FILE__ ~title:"meta: list runtime dependencies" ~file:"runtime-dependency-tags" ~tags:["meta"; "uses"] @@ fun () -> ( Fun.flip String_map.iter !known_paths @@ fun path {tag; _} -> Regression.capture @@ sf "%s: %s" tag path ) ; unit end let error mode = Printf.ksprintf @@ fun message -> match mode with | Ignore -> () | Warn -> Log.warn "%s" message | Fail -> Test.fail "%s" message (* Prepare parameters of a [Test.register]-like function. *) let wrap ~file ~title ~ ?(uses = []) ?(uses_node = true) ?(uses_client = true) ?(uses_admin_client = true) ~run_test () = (* Add default uses. *) let uses = if uses_node then Uses.octez_node :: uses else uses in let uses = if uses_client then Uses.octez_client :: uses else uses in let uses = if uses_admin_client then Uses.octez_admin_client :: uses else uses in (* Add [uses] into [tags]. *) let = String_set.of_list (List.map (fun (uses : Uses.t) -> uses.tag) uses) in let = String_set.union (String_set.of_list tags) uses_tags in (* Wrap [run_test] to check tags. In the future, we could use [Unix.chroot] to implement a sandbox that prevents using files that were not declared in [uses]. Or even just [Unix.chdir], if we assume that we only use relative paths, in which case we need to override [Tezt.Base.project_root] though. [chdir] would let tests use [/tmp] and system executables more easily. *) let = ref uses_tags in let run_test () = (* Check that [~uses] exist. Allows to fail earlier and with better error messages. *) let uses_that_do_not_exist = Fun.flip List.filter uses @@ fun uses -> not (Sys.file_exists uses.path) in (match uses_that_do_not_exist with | [] -> () | _ :: _ -> let paths = Fun.flip List.map uses_that_do_not_exist @@ fun uses -> uses.path in error !error_mode_for_non_existing_use "In %S, test %S requires %s which do(es) not exist." file title (String.concat ", " (List.map (sf "'%s'") paths))) ; (* Set hook so that tests can only call [Uses.path] on allowed paths. *) (Uses.path_handler := fun uses -> (* Do *not* use [Uses.path uses] here; use [uses.path]. Otherwise you'll get a stack overflow as the hook will trigger itself. *) unused_uses_tags := String_set.remove uses.tag !unused_uses_tags ; if not (String_set.mem uses.tag uses_tags) then error !error_mode_for_missing_use "In %S, test %S is not allowed to use %S. Try to add '%s' to its \ ~uses." file title uses.path uses.tag) ; (* Actually run the test. *) let* () = run_test () in (* Check for unused tags. *) String_set.iter (error !error_mode_for_useless_use "In %S, test %S was declared with '%s' in its ~uses but did not call \ Uses.path on it." file title) !unused_uses_tags ; unit in (* Return information that will be needed to register tests. *) (String_set.elements all_tags, run_test) module Test = struct include Test let register ~__FILE__:file ~title ~ ?uses ?uses_node ?uses_client ?uses_admin_client ?seed run_test = let , run_test = wrap ~file ~title ~tags ?uses ?uses_node ?uses_client ?uses_admin_client ~run_test () in Test.register ~__FILE__:file ~title ~tags ?seed run_test end module Regression = struct include Regression let register ~__FILE__:file ~title ~ ?uses ?uses_node ?uses_client ?uses_admin_client ?file:output_file run_test = let , run_test = wrap ~file ~title ~tags ?uses ?uses_node ?uses_client ?uses_admin_client ~run_test () in Regression.register ~__FILE__:file ~title ~tags ?file:output_file run_test end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>