Detailed Description
      The terminology used in the embodiments of the application is for the purpose of describing particular embodiments only and is not intended to be limiting of the application. As used in this specification and the appended claims, the singular forms "a," "an," and "the" are intended to include the plural forms as well, unless the context clearly indicates otherwise. It should also be understood that the term "and/or" as used herein refers to any or all possible combinations including one or more of the associated listed items.
      It should be understood that although the terms first, second, third, etc. may be used in embodiments of the present application to describe various information, these information should not be limited to these terms. These terms are only used to distinguish one type of information from another. For example, first information may also be referred to as second information, and similarly, second information may also be referred to as first information, without departing from the scope of the application. Depending on the context, furthermore, the word "if" used may be interpreted as "at … …" or "at … …" or "in response to a determination".
      The embodiment of the application provides a testing method for realizing random testing, which can be applied to any equipment, such as testing equipment, and is shown in fig. 1, and is a flow chart of the method, and the method can comprise the following steps:
       step 101, determining the number of target layers according to a first data structure and the number of tests; wherein the target number of levels is less than or equal to the number of levels of the first data structure. 
      In one example, before determining the target number of layers according to the first data structure and the number of tests, the first data structure may be further obtained according to attribute data supported by the database to be tested. Specifically, according to attribute data supported by a database to be tested, a plurality of target parameters and association relations of the plurality of target parameters can be determined; then, according to the multiple target parameters and the incidence relation of the multiple target parameters, a first data structure is obtained; the first data structure is in a tree structure, the nodes of the first data structure correspond to target parameters, and the node association relations of the first data structure correspond to the association relations of the target parameters.
      In one example, determining the target number of layers based on the first data structure and the number of tests may include, but is not limited to: and determining the original level number of the first data structure according to the first data structure and the test number, and determining the target level number according to the original level number.
      The method comprises the steps of obtaining a first substructure corresponding to the difference between the number of original layers and 1 from a first data structure, wherein the number of paths corresponding to the first substructure is smaller than or equal to the number of tests; and acquiring a second substructure corresponding to the original hierarchy number from the first data structure, wherein the number of paths corresponding to the second substructure is larger than the test number.
      Step 102, obtaining a second data structure according to the first data structure and the target level number.
      Specifically, a third sub-structure corresponding to the target number of layers may be obtained from the first data structure, and a second data structure corresponding to the target number of layers may be obtained according to the third sub-structure.
      Step 103, obtaining the test number of paths to be tested according to the second data structure.
      Specifically, a preamble traversal algorithm is adopted to acquire the test number of paths to be tested from the second data structure; or, acquiring the test number of paths to be tested from a second data structure by adopting a medium-order traversal algorithm; or, acquiring the test number of paths to be tested from the second data structure by adopting a subsequent traversal algorithm.
      And 104, testing according to the number of paths to be tested.
      In the above embodiment, the database to be tested may be an SQL (Structured Query Language ) database. In addition, the attribute data supported by the database to be tested may be a grammar specification, such as an SQL grammar specification. The first data structure may be a grammar map, such as a SQL grammar map. The second data structure may be a syntax tree, such as a SQL syntax tree. Of course, the foregoing is merely one example of a database, attribute data, a first data structure, and a second data structure, and is not particularly limited thereto.
      In one example, the above execution sequence is only given for convenience of description, and in practical application, the execution sequence between steps may be changed, which is not limited. Moreover, in other embodiments, the steps of the corresponding methods need not be performed in the order shown and described herein, and the methods may include more or less steps than described herein. Furthermore, individual steps described in this specification, in other embodiments, may be described as being split into multiple steps; various steps described in this specification, in other embodiments, may be combined into a single step.
      Based on the technical scheme, in the embodiment of the application, the grammar map can be acquired according to the grammar specification supported by the database to be tested, the grammar map is converted into the grammar tree, and the hierarchical number of the grammar tree is smaller than or equal to that of the grammar map, so that when a plurality of paths to be tested are acquired according to the grammar tree and tested according to the paths to be tested, the paths to be tested can cover the trunk path of the grammar tree and selectively cover the branch paths of the grammar tree, thereby controlling the coverage rate of random test, solving the problem of uncontrollable coverage rate of random test, ensuring the maximum coverage rate under test scenes and reducing redundant paths to be tested.
      The embodiment of the application provides a testing method for realizing random testing, which can be applied to any equipment, such as testing equipment, and is shown in fig. 2, which is a flow chart of the method, and the method can comprise the following steps:
       Step 201, a grammar map is obtained according to grammar specifications supported by a database to be tested. 
      The database to be tested is specifically an SQL (Structured Query Language structured query language) database; the grammar specification is specifically SQL grammar specification; the grammar map is specifically an SQL grammar map.
      The obtaining of the grammar graph according to the grammar specification supported by the database to be tested may include: determining a plurality of target parameters and association relations of the plurality of target parameters according to the grammar specification; acquiring a grammar according to the association relation between a plurality of target parameters and a plurality of target parameters; the grammar map is in a tree structure, nodes of the grammar map correspond to target parameters, and node association relations of the grammar map correspond to association relations of a plurality of target parameters.
      Step 202, determining a target level number of the syntax tree according to the syntax diagram and the test number, wherein the target level number may be smaller than or equal to the level number of the syntax diagram.
      In one example, to determine a target level number of the syntax tree, an original level number of the syntax diagram is determined from the syntax diagram and the test number, and the target level number of the syntax tree is determined from the original level number.
      When the first substructure corresponding to the difference between the number of the original layers and 1 is obtained from the grammar, the number of paths corresponding to the first substructure is less than or equal to the number of tests. When the second substructure corresponding to the original hierarchy number is acquired from the grammar, the number of paths corresponding to the second substructure is greater than the number of tests.
      And step 203, acquiring a grammar tree according to the grammar map and the target hierarchical quantity.
      Specifically, a third substructure corresponding to the target number of levels may be obtained from the grammar map, and a grammar tree corresponding to the target number of levels may be obtained according to the third substructure.
      Step 204, obtaining the test number of paths to be tested according to the syntax tree.
      Specifically, a preamble traversal algorithm may be used to obtain the number of paths to be tested from the syntax tree; or acquiring the test number of paths to be tested from the grammar tree by adopting a medium-order traversal algorithm; or acquiring the test number of paths to be tested from the grammar tree by adopting a subsequent traversal algorithm.
      And step 205, testing according to the number of paths to be tested.
      In one example, the above execution sequence is only given for convenience of description, and in practical application, the execution sequence between steps may be changed, which is not limited. Moreover, in other embodiments, the steps of the corresponding methods need not be performed in the order shown and described herein, and the methods may include more or less steps than described herein. Furthermore, individual steps described in this specification, in other embodiments, may be described as being split into multiple steps; various steps described in this specification, in other embodiments, may be combined into a single step.
      Based on the technical scheme, in the embodiment of the application, the grammar map can be acquired according to the grammar specification supported by the database to be tested, the grammar map is converted into the grammar tree, and the hierarchical number of the grammar tree is smaller than or equal to that of the grammar map, so that when a plurality of paths to be tested are acquired according to the grammar tree and tested according to the paths to be tested, the paths to be tested can cover the trunk path of the grammar tree and selectively cover the branch paths of the grammar tree, thereby controlling the coverage rate of random test, solving the problem of uncontrollable coverage rate of random test, ensuring the maximum coverage rate under test scenes and reducing redundant paths to be tested.
      Based on the same application concept as the above method, another testing method is provided in the embodiment of the present application, where the method is used to implement random testing, and the method may include: acquiring a second data structure according to the first data structure; the target number of levels of the second data structure is less than or equal to the number of levels of the first data structure; acquiring a plurality of paths to be tested according to a second data structure; and testing according to the multiple paths to be tested.
      In contrast to the above manner, in this embodiment, when the second data structure is acquired, as long as the target number of layers of the second data structure is less than or equal to the number of layers of the first data structure, the target number of layers may be empirically configured, or may be determined based on the number of tests, which is not limited.
      Based on the same application concept as the above method, another testing method is also provided in the embodiment of the present application, and the method may be used to implement random testing, and the method may include: acquiring a second data structure according to the first data structure and the test quantity; acquiring the test number of paths to be tested according to the second data structure; and testing according to the number of paths to be tested.
      In contrast to the above manner, in this embodiment, when the second data structure is acquired, the second data structure is acquired only according to the first data structure and the number of tests, and the target number of layers of the second data structure and the number of layers of the first data structure are not considered, which is not limited.
      The above test method is further described below in conjunction with specific application scenarios.
      In one example, the database may be a repository that organizes, stores, and manages data according to a data structure, and the types of databases may include, but are not limited to: SQL, OSS (Object Storage Service ), tableStore (table storage), HBase (Hadoop Database), HDFS (Hadoop Distributed FILE SYSTEM ), mySQL, etc., of course, these are just examples of Database types and are not limiting on the types of databases.
      In the embodiment of the application, the database is subjected to random test to solve the problem of uncontrollable random test coverage rate of the database, but the database which needs to be subjected to random test can be an SQL database, or can be an OSS database, tableStore database, HBase database, HDFS database, mySQL database and the like, and the method is not limited, and the SQL database is taken as an example for subsequent description, namely, the method is used for carrying out random test on the SQL database to solve the problem of uncontrollable random test coverage rate of the SQL database.
      In the embodiment of the present application, referring to fig. 3, which is a schematic diagram of a test method, an SQL grammar map may be constructed according to an SQL grammar specification supported by an SQL database, and the SQL grammar map may be converted into an SQL grammar tree, and a plurality of paths to be tested may be obtained according to the SQL grammar tree. Because the hierarchical number of the SQL grammar tree is smaller than or equal to that of the SQL grammar map, when a plurality of paths to be tested are acquired according to the SQL grammar tree, the paths to be tested can cover the trunk path of the SQL grammar tree and selectively cover the branch paths of the SQL grammar tree, so that the coverage rate of random test is controlled, and the problem that the coverage rate of the random test is uncontrollable is solved.
      Referring to fig. 4, a flow chart of a testing method in an embodiment of the application is shown, the testing method may be used to implement random testing of an SQL database, and the method may include the following steps:
       Step 401, acquiring an SQL grammar graph according to an SQL grammar specification supported by an SQL database. 
      The SQL grammar specification supported by the SQL database refers to an SQL statement which is supported by the SQL database, that is, when a user accesses the SQL database, the SQL statement of the SQL grammar specification can be adopted, so that the SQL database can identify and process the SQL statement.
      The SQL grammar specification supported by the SQL database is related to the SQL database, and the SQL grammar specification is not limited and can comprise but is not limited to: building a library, building a table, building a view, querying, adding, deleting, modifying and the like. For example, the following examples are SQL grammar specifications, which are, of course, just a few simple examples, and the contents of which are more numerous.
      SELECT$select_expr FROM_table where$where_condition order by pk。
      SELECT_ONE_TABLE:select$select_expr FROM_table where$where_condition order by pk。
      SELECT:select$select_expr from table。
      In one example, an SQL grammar map can be constructed based on an SQL grammar specification supported by an SQL database. Specifically, a plurality of target parameters and the association relation of the plurality of target parameters are determined according to the SQL grammar specification. And acquiring an SQL grammar according to the association relations of the target parameters and the target parameters, wherein each node of the SQL grammar corresponds to one target parameter, and the node association relation corresponds to the association relation of the target parameters.
      For example, for the SQL syntax specification "SELECT: SELECT $select_ expr from table" described above, the following target parameters may be determined: target parameter 1"select", target parameter 2"select", target parameter 3"select_expr", target parameter 4"from", and target parameter 5"table". The association relationship of the plurality of target parameters may be: target parameter 1 is a parent parameter of target parameter 2, and target parameter 2 is a child parameter of target parameter 1; target parameter 1 is a parent parameter of target parameter 3, and target parameter 3 is a child parameter of target parameter 1; target parameter 1 is a parent parameter of target parameter 4, and target parameter 4 is a child parameter of target parameter 1; target parameter 1 is a parent parameter of target parameter 5, and target parameter 5 is a child parameter of target parameter 1; furthermore, the target parameter 2, the target parameter 3, the target parameter 4, and the target parameter 5 may be in an and relationship, i.e., the target parameter 2, the target parameter 3, the target parameter 4, and the target parameter 5 together constitute one execution statement.
      Referring to FIG. 5A, there is shown an SQL syntax diagram for the SQL syntax specification "SELECT: SELECT $select_ expr from table", which, of course, is merely an example and is not limiting.
      As can be seen from fig. 5A, each node of the SQL syntax corresponds to one target parameter, such as target parameter 1, target parameter 2, target parameter 3, target parameter 4, target parameter 5, and so on. The association relation between the nodes of the SQL grammar is the association relation of a plurality of target parameters, such as parent-child relation, relationship or the like. Of course, the above are just a few examples of the association relationship, and no limitation is made thereto.
      For another example, assume that the SQL grammar specification further comprises: select_ expr: the constant field function expression may then determine the following target parameters: target parameter "constant", target parameter "field", target parameter "function", target parameter "expression", these target parameters are used to replace the target parameter 3"select_expr". The target parameters 3 are parent parameters of these target parameters, which are child parameters of the target parameters 3.
      The target parameter 'constant', the target parameter 'field', the target parameter 'function' and the target parameter 'expression' can be in a 'OR' relationship, namely any one of the target parameter 'constant', the target parameter 'field', the target parameter 'function' and the target parameter 'expression' forms an execution statement.
      Referring to FIG. 5B, for the SQL syntax specifications "SELECT: SELECT $select_ expr from table" and SQL syntax specification "$select_ expr" described above: the SQL syntax of the constant |field|function|expression "is, of course, just one example and is not limited thereto. It is apparent from fig. 5B that each node of the SQL grammar map corresponds to one target parameter, and the association relationship between nodes of the SQL grammar map is an association relationship of a plurality of target parameters, such as a parent-child relationship, a relationship, or a relationship.
      It should be noted that the target parameter 2, the target parameter 3, the target parameter 4, and the target parameter 5 may be in an "and" relationship, and the target parameter "constant", the target parameter "field", the target parameter "function", and the target parameter "expression" may be in an "or" relationship, and the two relationships are embodied in different colors.
      Further, regarding the target parameter "constant", the target parameter "field", the target parameter "function", the target parameter "expression" and the like, there may be sub-parameters of the target parameter, for example, the sub-parameters corresponding to the target parameter "expression" may include: the target parameter "function", the target parameter "operator", the target parameter "field", the target parameter "expression", and so on, are not limited thereto.
      Referring to fig. 5C, this SQL syntax diagram is an example of a 4-layer tree structure, and of course, in practical application, the SQL syntax diagram is more complex than fig. 5C, and the content of this SQL syntax diagram is not limited by the present application, and fig. 5C is taken as an example for illustration.
      Since the objective parameter "function" of the fourth layer and the objective parameter "function" of the third layer are both "functions", there is a recursive relationship between the objective parameter "function" of the fourth layer and the objective parameter "function" of the third layer. Since the target parameter "expression" of the fourth layer and the target parameter "expression" of the third layer are both "expressions", there is a recursive relationship between the target parameter "expression" of the fourth layer and the target parameter "expression" of the third layer.
      Step 402, determining the original hierarchical number of the SQL grammar according to the SQL grammar and the test number.
      In one example, when the first substructure corresponding to the difference between the number of original layers and 1 is obtained from the SQL grammar, the number of paths corresponding to the first substructure may be less than or equal to the number of tests. Moreover, when the second substructure corresponding to the original hierarchical number is obtained from the SQL grammar, the number of paths corresponding to the second substructure may be greater than the number of tests.
      For example, when the SQL syntax is the substructure 1 corresponding to the number of layers 1, then the number of paths corresponding to the substructure 1 is 1, that is, "SELECT constant from table", and "SELECT" of the first line is represented by "SELECT constant from table". When the SQL syntax is the sub-structure 2 corresponding to the level number 2, the number of paths corresponding to the sub-structure 2 is 1, namely, the "select constant from table", that is, the select, $select_ expr (represented by a constant), the from and the table are in the and relationship, and correspond to the same path.
      Referring to fig. 5B, when the SQL syntax is a substructure 3 corresponding to the number of layers 3, the number of paths corresponding to the substructure 3 may be 4, that is, the paths may be: "select constant from table", "select field from table", "select function from table", "select expression from table", that is, the relationship where the constants, fields, functions, expressions are "OR", corresponds to four paths.
      Referring to fig. 5C, when the SQL syntax is a substructure 4 corresponding to the number of layers 4, the number of paths corresponding to the substructure 4 may be 7, that is, the paths may include: the "select constant from table", "select field from table", "select function from table", "select operator from table", "select field from table", "select expression from table", that is, the relationship that the functions, operators, fields, expressions in the fourth layer of the SQL syntax graph are "OR", may correspond to four paths for replacing the "expression" of the third layer of the SQL syntax graph.
      In one example, the test number is a random test number for an SQL test scenario, meaning that a total of several random tests are performed. For example, assuming that the number of tests is 3, since the number of paths 1 corresponding to the substructure 2 of the number of layers 2 (i.e., the difference between the number of layers 3 and 1) is smaller than the number of tests 3, and the number of paths 4 corresponding to the substructure 3 of the number of layers 3 is larger than the number of tests 3, the original number of layers of the SQL syntax is 3.
      For another example, assuming that the number of tests is 6, since the number of paths 4 corresponding to the substructure 3 of the number of layers 3 (i.e., the difference between the number of layers 4 and 1) is smaller than the number of tests 6, and the number of paths 7 corresponding to the substructure 4 of the number of layers 4 is greater than the number of tests 6, the original number of layers of the SQL syntax graph is 4.
      In summary, the original hierarchical number of the SQL grammar graph may be determined according to the SQL grammar graph and the test number, for example, starting from the root node of the SQL grammar graph, the original hierarchical number of the SQL grammar graph is determined by using a hierarchical traversal algorithm, that is, traversing an original hierarchical number, so that the number of paths of the sub-structure corresponding to the difference between the original hierarchical number and 1 is smaller than or equal to the test number, and the number of paths of the sub-structure corresponding to the original hierarchical number is greater than the test number, where the original hierarchical number is used for determining the hierarchical number of the SQL grammar tree.
      In step 403, the target hierarchical number of the SQL syntax tree is determined according to the original hierarchical number of the SQL syntax graph, and the target hierarchical number of the SQL syntax tree may be smaller than or equal to the original hierarchical number of the SQL syntax graph.
      Referring to the above embodiment, since the original hierarchical number of the SQL syntax graph is smaller than or equal to the hierarchical number of the SQL syntax graph and the target hierarchical number of the SQL syntax tree is smaller than or equal to the original hierarchical number of the SQL syntax graph, the target hierarchical number of the SQL syntax tree may be smaller than or equal to the hierarchical number of the SQL syntax graph. For convenience of description, the description will be given taking an example in which the target hierarchical number of the SQL syntax tree is equal to the original hierarchical number of the SQL syntax diagram, for example, assume that the original hierarchical number of the SQL syntax diagram is 3, the target hierarchical number of the SQL syntax tree is 3, and the hierarchical number of the SQL syntax diagram is 4.
      Step 404, obtaining a third substructure corresponding to the target hierarchical number from the SQL grammar map, and obtaining an SQL grammar tree corresponding to the target hierarchical number according to the third substructure.
      For example, referring to fig. 5C, if the number of layers of the SQL syntax diagram is 4 and the target number of layers of the SQL syntax tree is 3, a third sub-structure of 3 layers, that is, a third sub-structure, may be obtained from the SQL syntax diagram, as shown in fig. 5B. For another example, assuming that the number of target hierarchies of the SQL syntax tree is 4, a third sub-structure of 4 layers, that is, a third sub-structure, is obtained from the SQL syntax diagram, which can be seen in FIG. 5C.
      In one example, the third substructure may be determined as an SQL syntax tree. For example, assuming that the target hierarchical number of SQL syntax trees is 3, the third sub-structure shown in FIG. 5B may be determined as an SQL syntax tree.
      In another example, the third substructure may be determined as a SQL syntax tree, or the third substructure may be modified (e.g., the recursive and directional relationships in the third substructure are removed), and the modified third substructure may be determined as a SQL syntax tree. For example, assuming that the target hierarchical number of SQL syntax trees is 4, the third sub-structure shown in FIG. 5C may be determined as an SQL syntax tree. Or, the recursive relation of the third substructure shown in fig. 5C is removed, resulting in the substructure shown in fig. 5D, and the substructure is determined as an SQL syntax tree.
      Step 405, obtaining a test number of paths to be tested according to the SQL syntax tree.
      For example, the test number of paths to be tested is obtained from an SQL grammar tree by adopting a preamble traversal algorithm; or acquiring the test number of paths to be tested from the SQL grammar tree by adopting a medium-order traversal algorithm; or acquiring the test number of paths to be tested from the SQL grammar tree by adopting a subsequent traversal algorithm.
      Assuming that referring to the SQL syntax tree shown in FIG. 5D, there are 7 paths in total, such as "select constant from table", "select field from table", "select function from table", "select operator from table", "select field from table", "select expression from table", if the number of tests is 6, 6 paths are selected from the 7 paths as paths to be tested, and the selection manner is not limited as long as 6 paths are selected from the 7 paths.
      When selecting a test number of paths to be tested from all paths, a preamble traversal algorithm, a mid-order traversal algorithm, or a post-order traversal algorithm may be employed. The preamble traversal algorithm, the middle-order traversal algorithm and the subsequent traversal algorithm are tree-structured traversal algorithms, represent different traversal sequences, and do not limit the traversal process. Of course, other traversal algorithms may be used to select the number of paths to be tested, which is not limited.
      And step 406, testing according to the number of paths to be tested.
      Specifically, after the number of paths to be tested is obtained according to the SQL syntax tree, the test can be performed according to the number of paths to be tested, such as random test, and the test process is not limited.
      In one example, the above execution sequence is only given for convenience of description, and in practical application, the execution sequence between steps may be changed, which is not limited. Moreover, in other embodiments, the steps of the corresponding methods need not be performed in the order shown and described herein, and the methods may include more or less steps than described herein. Furthermore, individual steps described in this specification, in other embodiments, may be described as being split into multiple steps; various steps described in this specification, in other embodiments, may be combined into a single step.
      Based on the technical scheme, in the embodiment of the application, a plurality of paths to be tested are obtained according to the SQL grammar tree, and can cover the trunk path of the SQL grammar tree and selectively cover the branch paths of the SQL grammar tree, so that the coverage rate of random test can be controlled, the problem of uncontrollable coverage rate of random test is solved, the maximum coverage rate under a test scene is ensured, and redundant paths to be tested can be reduced.
      For example, assuming that the number of tests is 3, the number of target levels of the SQL syntax tree is 3, i.e., the number of paths of the SQL syntax tree is 4, i.e., the paths may be: the "select constant from table", "select field from table", "select function from table", "select expression from table", that is, 3 paths are selected from these 4 paths, which are corresponding to the first 3-layer structure such as the select constant from table "," select field from table "," select function from table ", whichever is selected.
      However, if 3 paths are selected from all 7 paths instead of the 4 paths corresponding to the SQL syntax tree, the selected paths may correspond to a 4-layer structure such as "select operator from table", "select field from table", "select expression from table".
      Obviously, the path corresponding to the front 3-layer structure has a larger probability of being used than the path corresponding to the 4-layer structure, and may be referred to as a backbone path of the SQL syntax tree, while the path corresponding to the 4-layer structure has a smaller probability of being used, and may be referred to as a branch path of the SQL syntax tree.
      In the embodiment of the application, the target hierarchical number of the SQL grammar tree is controlled through the test number, so that the target hierarchical number of the SQL grammar tree is smaller than or equal to the hierarchical number of the SQL grammar map, and the trunk path of the SQL grammar tree can be covered as much as possible, and the branch path of the SQL grammar tree can be selectively covered.
      Based on the same application concept as the method, an embodiment of the present application further provides a testing device, as shown in fig. 6, which is a structural diagram of the testing device, where the testing device includes:
       a determining module 61, configured to determine a target level number according to the first data structure and the test number; wherein the target number of levels is less than or equal to the number of levels of the first data structure; 
       an obtaining module 62, configured to obtain a second data structure according to the first data structure and the target number of layers; acquiring the test number of paths to be tested according to the second data structure; 
       And the test module 63 is configured to perform a test according to the number of paths to be tested. 
      The acquiring module 62 is further configured to acquire a first data structure according to attribute data supported by the database to be tested; the acquiring module 62 is specifically configured to, when acquiring the first data structure according to the attribute data supported by the database to be tested: determining a plurality of target parameters and association relations of the plurality of target parameters according to the attribute data; acquiring a first data structure according to the target parameters and the association relation of the target parameters; the first data structure is a tree structure, and the node of the first data structure corresponds to a target parameter and the node association relationship of the first data structure corresponds to the association relationship of the target parameter.
      The determining module 61 is specifically configured to determine, according to the first data structure and the number of tests, the number of target levels when: determining the original hierarchical quantity of a first data structure according to the first data structure and the test quantity; and determining the target level number according to the original level number.
      Based on the same application concept as the method, the embodiment of the application further provides a testing device, which comprises: a processor and a machine-readable storage medium having stored thereon computer instructions that when executed by the processor perform the following:
       Determining a target level number according to the first data structure and the test number; wherein the target number of levels is less than or equal to the number of levels of the first data structure; 
       acquiring a second data structure according to the first data structure and the target level number; 
       Acquiring the test number of paths to be tested according to the second data structure; 
       And testing according to the number of paths to be tested. 
      Embodiments of the present application also provide a machine-readable storage medium having stored thereon a number of computer instructions; the computer instructions, when executed, perform the following:
       Determining a target level number according to the first data structure and the test number; wherein the target number of levels is less than or equal to the number of levels of the first data structure; 
       acquiring a second data structure according to the first data structure and the target level number; 
       Acquiring the test number of paths to be tested according to the second data structure; 
       And testing according to the number of paths to be tested. 
      Referring to fig. 7, which is a structural diagram of a test apparatus according to an embodiment of the present application, the test apparatus 70 may include: a processor 71, a network interface 72, a bus 73, and a memory 74. Memory 74 may be any electronic, magnetic, optical or other physical storage device that can contain or store information such as executable instructions, data, or the like. For example, the memory 74 may be: RAM (Radom Access Memory, random access memory), volatile memory, non-volatile memory, flash memory, a storage drive (e.g., hard drive), a solid state disk, any type of storage disk (e.g., optical disk, dvd, etc.).
      The system, apparatus, module or unit set forth in the above embodiments may be implemented in particular by a computer chip or entity, or by a product having a certain function. A typical implementation device is a computer, which may be in the form of a personal computer, laptop computer, cellular telephone, camera phone, smart phone, personal digital assistant, media player, navigation device, email device, game console, tablet computer, wearable device, or a combination of any of these devices.
      For convenience of description, the above devices are described as being functionally divided into various units, respectively. Of course, the functions of each element may be implemented in the same piece or pieces of software and/or hardware when implementing the present application.
      It will be appreciated by those skilled in the art that embodiments of the present application may be provided as a method, system, or computer program product. Accordingly, the present application may take the form of an entirely hardware embodiment, an entirely software embodiment or an embodiment combining software and hardware aspects. Furthermore, embodiments of the application may take the form of a computer program product on one or more computer-usable storage media (including, but not limited to, disk storage, CD-ROM, optical storage, etc.) having computer-usable program code embodied therein.
      The present application is described with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the application. It will be understood that each flow and/or block of the flowchart illustrations and/or block diagrams, and combinations of flows and/or blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, embedded processor, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions specified in the flowchart flow or flows and/or block diagram block or blocks.
      Moreover, these computer program instructions may also be stored in a computer-readable memory that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable memory produce an article of manufacture including instruction means which implement the function specified in the flowchart flow or flows and/or block diagram block or blocks.
      These computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational steps to be performed on the computer or other programmable apparatus to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide steps for implementing the functions specified in the flowchart flow or flows and/or block diagram block or blocks.
      The foregoing is merely exemplary of the present application and is not intended to limit the present application. Various modifications and variations of the present application will be apparent to those skilled in the art. Any modification, equivalent replacement, improvement, etc. which come within the spirit and principles of the application are to be included in the scope of the claims of the present application.