2 * Copyright (c) 2017 Lev Walkin <vlm@lionet.info>.
4 * Redistribution and modifications are permitted subject to BSD license.
6 #include <asn_internal.h>
7 #include <OBJECT_IDENTIFIER.h>
10 * Generate values from the list of interesting values, or just a random
11 * value up to the upper limit.
14 OBJECT_IDENTIFIER__biased_random_arc(asn_oid_arc_t upper_bound) {
15 const asn_oid_arc_t values[] = {0, 1, 127, 128, 129, 254, 255, 256};
18 switch(asn_random_between(0, 2)) {
20 idx = asn_random_between(0, sizeof(values) / sizeof(values[0]) - 1);
21 if(values[idx] < upper_bound) {
26 return asn_random_between(0, upper_bound);
33 asn_random_fill_result_t
34 OBJECT_IDENTIFIER_random_fill(const asn_TYPE_descriptor_t *td, void **sptr,
35 const asn_encoding_constraints_t *constraints,
37 asn_random_fill_result_t result_ok = {ARFILL_OK, 1};
38 asn_random_fill_result_t result_failed = {ARFILL_FAILED, 0};
39 asn_random_fill_result_t result_skipped = {ARFILL_SKIPPED, 0};
40 OBJECT_IDENTIFIER_t *st;
41 asn_oid_arc_t arcs[5];
42 size_t arcs_len = asn_random_between(2, 5);
47 if(max_length < arcs_len) return result_skipped;
52 st = CALLOC(1, sizeof(*st));
55 arcs[0] = asn_random_between(0, 2);
56 arcs[1] = OBJECT_IDENTIFIER__biased_random_arc(
57 arcs[0] <= 1 ? 39 : (ASN_OID_ARC_MAX - 80));
58 for(i = 2; i < arcs_len; i++) {
59 arcs[i] = OBJECT_IDENTIFIER__biased_random_arc(ASN_OID_ARC_MAX);
62 if(OBJECT_IDENTIFIER_set_arcs(st, arcs, arcs_len)) {
64 ASN_STRUCT_FREE(*td, st);
71 result_ok.length = st->size;