This application is based upon and claims the benefit of priority of the prior Japanese Patent Application No. 2009-132957, filed on Jun. 2, 2009, the entire contents of which are incorporated herein by reference.
This embodiment relates to a scenario creating apparatus, a scenario creating method, and a storage medium storing a scenario creating program.
In a case when a bug is fixed in an information processing system, or when a new function is added to the information processing system, for example, a tester or the like who is in charge of testing the information processing system performs testing to verify that such a fix or added app is not affecting other apps. For this reason, the tester performs similar testing every time the information processing system is modified. Such testing is called “recursion testing” or “regression testing”.
Now, an example of a testing technique according to the related art will be described with reference to
In the example illustrated in
The test terminal 11 transmits an HTTP (HyperText Transfer Protocol) request or the like to the Web server 13, in response to the operation performed by the tester H1. Upon receiving the HTTP request or the like, the Web server 13 transmits/receives a request or a response to/from the AP server 14. In the meantime, the AP server 14 transmits/receivers a request or a response to/from the DB server 15. In the following, a request and a response will be sometimes collectively referred to as “message”.
Then, for example, the test terminal 11 receives a response from the Web server 13, and outputs information corresponding to the received response on the Web browser. Then, the tester H1 checks the information outputted on the Web browser to determine pass/fail of testing.
In this way, the tester H1 performs testing on the information processing system 9. When performing recursion testing, the tester H1 performs the same operation as previously performed, and performs the same check as previously performed. While
Recently, with a view to reducing the number of man-hours required for recursion testing, an automatic testing technique has been proposed which carries out a part of recursion test automatically. Such an automatic testing technique will be described below with reference to the example illustrated in
Then, when performing recursion testing, for example, the tester H1 does a read operation that reads the test data after initializing various kinds of database held on the DB sever 15. When the read operation is performed, the test terminal 11 executes the operation procedure contained in the test data, and transmits a request to the Web server 13. Then, the test terminal 11 receives a response from the Web server 13, and determines pass/fail of the testing by determining whether or not the received response matches the response contained in the test data. In this way, by using the automatic testing technique, the tester H1 performs recursion testing without performing a predetermined operation procedure.
For instance, Japanese Laid-open Patent Publication No. 11-184900 and Japanese Laid-open Patent Publication No. 2007-264810 are known as in relation to the automatic testing technique.
According to an aspect of the invention, a scenario creating apparatus, which creates a scenario for verifying operation of an information processing system in which a plurality of servers including a database server are connected, includes a collector that collects messages transmitted and received between the plurality of servers, when operation of the information processing system is being verified by a terminal apparatus that performs verification of operation; an association unit that associates the collected messages with each other; a sorter that sorts work models in ascending order of time at which access is made to the database server, the work models each being a group of the associated messages; and a scenario creating unit that creates the scenario on the basis of the sorted work models.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention, as claimed.
The above-described embodiments of the present invention are intended as examples, and all embodiments of the present invention are not limited to including the features described above.
Reference may now be made in detail to embodiments of the present invention, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to like elements throughout.
The above-described automatic testing technique has a problem in that pass/fail of testing cannot be determined correctly in some cases. A specific description in this regard will be given with reference to
Specifically, in the example illustrated in
In addition, in the example illustrated in
In the example illustrated in
Here, as illustrated in
However, when the test T11 is executed using the test data D11, access cannot be made to the DB server 15 that has been updated in the test T12. Thus, there is a fear that the test terminal may receive from the Web server 13 a response different from a response contained in the test data D11. This causes a problem in which pass/fail of the testing cannot be determined correctly even though the information processing system is operating properly.
It is perceived that the operations of the respective servers illustrated in
As described above, since recursion testing is frequency performed in the field of information processing systems, the number of man-hours required for such recursion testing has been increasing. Under such a circumstance, the challenge is how to create test data that allows pass/fail of the testing to be determined correctly.
Hereinbelow, scenario creating apparatus, scenario creating method, and storage medium storing scenario creating program disclosed by this application will be described in detail with reference to the drawings. It should be noted that this embodiment does not limit the scenario creating apparatus, scenario creating method, and storage medium storing scenario creating program.
First, referring to
As illustrated in
The test terminal 11 is a terminal apparatus such as a personal computer operated by a tester. The load distribution apparatus 12 receives a request from the test terminal 11, and transfers the received request to the Web servers 13. For example, the load distribution apparatus 12 transfers a request in such a way that loads on the plurality of Web servers 13 become uniform. In response to the request from the test terminal 11, the Web servers 13 each transmit a response containing HTML (HyperText Markup Language) data, image data, and the like to the test terminal 11.
The AP server 14 has applications for implementing various kinds of service provided by the information processing system 1. In the example illustrated in
The DB server 15 stores various kinds of information. In the example illustrated in
Under such configuration, when testing is carried out by the tester on the information processing system 1, the scenario creating apparatus 100 according to Embodiment 1 creates a test scenario for replicating such testing.
Specifically, when testing is carried out by the tester on the information processing system 1, the scenario creating apparatus 100 collects various kinds of message transmitted/received by the test terminal 11 and between the individual servers. In the example illustrated in
Subsequently, the scenario creating apparatus 100 stores, among the collected messages, related messages in association with each other. The expression “related messages” as used herein refers to requests and responses transmitted/received between individual servers in response to predetermined requests and responses.
For example, in a case when a request Req1 is transmitted from the load distribution apparatus 12 to the Web servers 13, and a request Req2 is transmitted from the Web servers 13 to the AP server 14 in response to the request Req1, the requests Req1 and Reg2 are related. Also, suppose that a request Req3 is transmitted from the AP server 14 to the DB server 15 in response to the request Req2, and a response Res1 is transmitted from the DB server 15 to the AP server 14 in response to the request Req3. In such a case, the requests Req1, Req2, and Req3, and the response Res1 are related.
It should be noted that in the following, the process from when a request is transmitted from the test terminal 11 to the load distribution apparatus 12 to when a response is transmitted from the load distribution apparatus 12 to the test terminal 11 in response to the request will be referred to as “transaction”. Also, in the following, each group of messages within the same transaction which are associated with each other by the scenario creating apparatus 100 will be referred to as “work model”.
Subsequently, the scenario creating apparatus 100 sorts generated work models in ascending order of the time when access to the DB server 15 is started. Then, the scenario creating apparatus 100 generates a scenario on the basis of the sorted work models.
Referring to the example illustrated in
Then, since the test T12 makes access to the DB server 15 earlier than the test T11, the scenario creating apparatus 100 sorts the work models in the order of the work model M2 and the work model M1. Then, the scenario creating apparatus 100 creates a scenario on the basis of the sorted work models M2 and M1.
The scenario created in this way serves as test data for carrying out testing in the order of the test T12 and the test T11. Specifically, when the above-mentioned scenario is executed by the test terminal 11, first, the work model M2 is executed, and then the work model M1 is executed. That is, the work model M1 makes access to the DB server 15 after access to the DB server 15 is made by the work model M2. Therefore, upon executing the above-mentioned scenario when the information processing system 1 is operating properly, the test terminal 11 can receive the same responses as the responses received when the tests T11 and T12 are performed. Therefore, the test terminal 11 can correctly perform test pass/fail determination by using the scenario generated by the scenario creating apparatus 100.
In this way, the scenario creating apparatus 100 according to Embodiment 1 collects messages transmitted/received between individual servers, and associate messages transmitted/received within the same transactions with each other to generate work models. Then, the scenario creating apparatus 100 sorts the generated work models in ascending order of the time when access to the DB server 15 is started, thereby creating a scenario.
That is, the scenario creating apparatus 100 generates a scenario in such a way that the order of access to the DB server 15 when testing is carried out by the tester, and the order of access to the DB server 15 at the time when the scenario is executed become the same. Thus, the scenario generated by the scenario creating apparatus 100 makes it possible to determine pass/fail of testing correctly.
It should be noted that the scenario creating apparatus 100 according to Embodiment 1 also performs various kinds of processing other than those described above. For example, after sorting work models, the scenario creating apparatus 100 creates a scenario by multiplexing those work models which do not cause any problem even when carried out in parallel. By way of example, in the example illustrated in
Next, referring to
The IF unit 110 transmits/receives various kinds of data to/from an external apparatus. In the example illustrated in
The input unit 120 is an input device for inputting various kinds of information and operational instructions, and is, for example, a keyboard or a mouse. The tester performs testing by operating the input unit 120. The output unit 130 is an output device for outputting various kinds of information, and is, for example, a liquid crystal panel or a speaker. The tester determines pass/fail of testing by checking information displayed on the output unit 130, for example.
The control unit 140 has an internal memory for storing a control program, programs specifying various kinds of procedure and the like, and necessary data, and controls the scenario creating apparatus 100 as a whole. As in the example illustrated in
The collector 141 collects messages transmitted/received between individual servers when the operation of the information processing system 1 is being verified by the tester. Specifically, the collector 141 collects various kinds of message transmitted/received between the load distribution apparatus 12 and servers such as the Web servers 13 when a request is transmitted by the test terminal 11 to the load distribution apparatus 12, via the IF unit 110.
Referring to
Now, referring to
As illustrated in
As illustrated in
Returning to the explanation of
Referring to
In the example illustrated in
In such a case, the association unit 142 generates a work model by associating the requests Req11 to Req16 and the responses Res11 to Res16 illustrated in
Now, a supplemental description will be given of an attribute assigned to each work model. In Embodiment 1, the association unit 142 assigns an attribute “update type” to a work model which performs updating to the DB server 15. Also, the association unit 142 assigns an attribute “reference type (shared)” to a work model which does not perform updating to the DB server 15 and performs referencing with a shared lock. Also, the association unit 142 assigns an attribute “reference type (no lock)” to a work model which performs only referencing with no shared lock to the DB server 15.
For example, if updating and referencing are performed in the work model M3, the association unit 142 assigns the work model M3 with an attribute “update type”. If, for example, referencing with a shared lock and referencing with no shared lock are performed in the work model M4, the association unit 142 assigns the work model M4 with an attribute “reference type (shared lock). If, for example, only referencing with no shared lock is performed in the work model M5, the association unit 142 assigns the work model M5 with an attribute “reference type (no lock)”.
Referring to
As illustrated in
As illustrated in
As illustrated in
Returning to the explanation of
Referring to
It should be noted that in the examples illustrated in
That is, the work model M11 illustrated in
Now, suppose that the work models M11 to M13, M21, and M22 illustrated in
Returning to the explanation of
In Embodiment 1, by using a bubble sort, the swapper 144 swaps the order of work models while comparing each two adjacent work models. Specifically, the swapper 144 performs swapping beginning with the work model whose access start time is closest to the current time. For example, when performing swapping with respect to the work models illustrated in
For example, as illustrated in
Also, for example, as illustrated in
This is because if works models that access the same table are arranged in the order of “update type and reference type”, it is required that the two work models be processed in that order. For example, if a work model M7 that performs referencing to Table A is placed after a work model M6 that performs updating to Table A, it is required that the work model M7 be executed after Table A is updated by the work model M6. Therefore, in the case of the above-mentioned example, the swapper 144 does not swap the order of the work models M6 and M7.
On the other hand, if the “tables to be referenced/updated” by the two work models are different in the above-mentioned example, the swapper 144 swaps the two work models. This is because, as described above, the swapper 144 according to Embodiment 1 places a reference-type work model before an update-type work model.
Now, referring to
Returning to the explanation of
For example, as illustrated in
Also, if two work models to be compared are both “reference type” as illustrated in
Now, referring to
The multiplexer 145 swaps the work models illustrated in
Also, in addition to the multiplexing described above, the multiplexer 145 assigns information indicating that synchronization is to be performed (hereinafter, referred to as “synchronization information”). Specifically, the multiplexer 145 assigns synchronization information if the condition illustrated in the Remarks in
The above-mentioned processing will be described by way of an example. For example, suppose that two adjacent work models are placed in the order of “the work model M8 and the work model M9”. Then, suppose that the work model M8 is a reference-type one, and the work model M9 is an update-type one. In such a case, the multiplexer 145 assigns synchronization information between the work model M8 and the work model M9 so that the work model M9 is executed after execution of the work model M8 is finished. This is to prevent the work model M9 from being executed while the reference-type work model M8 is being executed.
Referring to
In such a case, the multiplexer 145 rearranges the work models illustrated in
The multiplexer 145 also assigns synchronization information between the work models M35 and M36, and the work models M37 and M38. Thus, the multiplexer 145 can prevent the work models M37 and M38 from being executed before execution of the work models M35 and M36 is finished.
Returning to the explanation of
It should be noted that in cases such as when it is not necessary to reduce the time required for test execution, the scenario creating unit 146 may create a scenario on the basis of work models sorted by the sorter 143.
[Scenario Creation Procedure]
Next, referring to
As illustrated in
Subsequently, among the messages collected by the collector 141, the association unit 142 associates messages transmitted/received within the same transactions with each other, thereby generating work models (operation S13).
Subsequently, the sorter 143 performs sorting (operation S14). Specifically, the sorter 143 sorts the work models generated by the association unit 142 in ascending order of the start time of access to the DB server 15. It should be noted that the sorting performed by the sorter 143 will be described later with reference to
Subsequently, the swapper 144 performs swapping (operation S15). Specifically, the swapper 144 swaps the order of the work models sorted by the sorter 143 so that work models of the same attribute become adjacent to each other. It should be noted that the swapping performed by the swapper 144 will be described later with reference to
Subsequently, the multiplexer 145 performs multiplexing (operation S16). Specifically, the multiplexer 145 multiplexes the work models that have been swapped by the swapper 144. It should be noted that the multiplexing performed by the multiplexer 145 will be described later with reference to
Then, the scenario creating unit 146 creates a scenario on the basis of the work models that have been multiplexed by the multiplexer 145, and stores the created scenario into the scenario storing unit 152 (operation S17).
[Sorting Procedure]
Next, referring to
First, in the example illustrated in
Then, as illustrated in
Subsequently, the sorter 143 repeats the procedure in operations S102 to S110 until a condition “n≦1” is met. Here, since “n=5”, the condition “n≦1” is not met. Therefore, the sorter 143 substitutes “1” into a variable i (operation S103).
Then, the sorter 143 repeats the procedure in operations S104 to S108 until a condition “i=n” is met. Here, since “n=5” and “i=1”, the condition “i=n” is not met. Therefore, the sorter 143 compares the start time of access to the DB server 15 in the work model of Z(i), with the start time of access to the DB server 15 in the work model of Z(i+1) (operation S105).
Then, if the access start time in Z(i) is not larger than the access start time in Z(i+1), the sorter 143 swaps the work model substituted in Z(i) and the work model substituted in Z(i+1) (operation S106). Specifically, as illustrated in
It should be noted that the expression “time A is larger than time B” as used in this specification means that time A is closer to the current time than time B. In other words, the expression “time A is smaller than time B” means that time A is past with reference to time B.
On the other hand, if the access start time in Z(i) is larger than the access start time in Z(i+1), the sorter 143 does not swap the work model substituted in Z(i) and the work model substituted in Z(i+1).
Here, since “i=1”, the sorter 143 compares Z(1) and Z(2) with each other. That is, in the case of the above-mentioned example, the sorter 143 compares the access start time in the work model M22 with the access start time in the work model M21. As illustrated in
Subsequently, the sorter 143 increments the variable i (operation S107). Here, the sorter 143 updates the variable i to “2”. That is, since “n=5” and “i=2”, the condition “i=n” in operation S104 is not met. Therefore, the sorter 143 performs the processing in operations S105 to S107. Specifically, the sorter 143 compares Z(2) with Z(3).
That is, in the case of the above-mentioned example, the sorter 143 compares the access start time in the work model M21 with the access start time in the work model M13. As illustrated in
In this way, the sorter 143 repeats the procedure in operations S104 to S108 until the condition “i=n” in operation S104 is met. Then, when the condition “i=n” is met, the sorter 143 decrements the variable n (operation S109). Then, the sorter 143 repeats the procedure in operations S102 to 5110 until the condition “n≦1” in operation S102 is met.
[Swapping Procedure]
Next, referring to
First, as illustrated in
Subsequently, the swapper 144 repeats the procedure in operations S202 to S211 until a condition “n≦1” is met. Here, since “n=5”, the condition “n≦1” is not met. Therefore, the swapper 144 substitutes “1” into a variable i (operation S203).
Then, the swapper 144 repeats the procedure in operations S204 to S209 until a condition “i=n” is met. Here, since “n=5” and “i=1”, the condition “i=n” is not met. Therefore, the swapper 144 performs swapping determination by comparing Z(i) with Z(i+1) (operation S205). It should be noted that the swapping determination performed by the swapper 144 will be described later with reference to
If it is determined as a result of the swapping determination to “perform swapping” (Yes in operation S206), the swapper 144 swaps the work model substituted in Z(i) and the work model substituted in Z(i+1) (operation S207). Specifically, as illustrated in
If it is determined as a result of the swapping determination “not to perform swapping” (No in operation S206), the swapper 144 does not swap the work model substituted in Z(i) and the work model substituted in Z(i+1).
Subsequently, the swapper 144 increments the variable i (operation S208). Here, the swapper 144 updates the variable i to “2”. That is, since “n=5” and “i=2”, the condition “i=n” in operation S204 is not met. Therefore, the swapper 144 performs the processing in operations S205 to S208.
In this way, the swapper 144 repeats the procedure in operations S204 to S208 until the condition “i=n” in operation S204 is met. Then, when the condition “i=n” is met, the swapper 144 decrements the variable n (operation S210). Then, the swapper 144 repeats the procedure in operations S202 to S211 until the condition “n≦1” in operation S202 is met.
[Swapping Procedure]
Next, referring to
When performing swapping determination, first, the swapper 144 substitutes the name of a table referenced or updated in the work model of Z(i) into a variable ZT(i) (operation S301). Also, the swapper 144 substitutes the name of a table referenced or updated in the work model of Z(i+1) into a variable ZT(i+1) (operation S301).
Subsequently, if the work model of Z(i) is “update type” (Yes in operation S302), the swapper 144 determines “not to perform swapping” (operation S303). Specifically, the swapper 144 determines not to perform swapping of Z(i) and Z(i+1). This indicates a case in which, among the conditions illustrated in
On the other hand, if the work model of Z(i) is not “update type” (No in operation S302), the swapper 144 determines whether or not ZT(i) and ZT(i+1) are equal (operation S304). Then, if ZT(i) and ZT(i+1) are equal (Yes in operation S304), the swapper 144 determines “not to perform swapping” (operation S305). This indicates a case in which, among the conditions illustrated in
On the other hand, if ZT(i) and ZT(i+1) are different (No in operation S304), the swapper 144 determines to “perform swapping” (operation S306). This indicates a case in which, among the conditions illustrated in
This will be described by way of the above-mentioned example. If “i=1”, the work model of Z(i)=Z(1) is the work model M13, and the work model of Z(i+1)=Z(2) is the work model M22. As illustrated in
[Multiplexing Procedure]
Next, referring to
It should be noted that the array Y(j, k) illustrated in
Hereinbelow, the procedure illustrated in
First, as illustrated in
Subsequently, the multiplexer 145 substitutes the number of elements into a variable n, and substitutes “1” into a variable i (operation S402). In the example illustrated in
Subsequently, the multiplexer 145 repeats the procedure in operations S403 to S417 until a condition “n≦1” is met. Here, since “n=21”, the condition “n≦1” is not met. Therefore, the multiplexer 145 substitutes “i” into a variable j (operation S404). Here, since “i=1”, the multiplexer 145 substitutes “1” into the variable j.
Subsequently, the multiplexer 145 repeats the procedure in operations S405 to S413 until a condition “j<1” is met. Here, since “j=1”, the condition “j<1” is not met. Therefore, the multiplexer 145 substitutes X(j) into a variable k (operation S406). Here, since “j=1”, the multiplexer 145 substitutes “0” into the variable k.
Subsequently, the multiplexer 145 repeats the procedure in operations S407 to S411 until a condition “k<1” is met. Here, since “k=0”, the condition “k<1” is met. Therefore, the multiplexer 145 decrements the variable j (operation S412). Here, since “j=1”, the multiplexer 145 updates the variable j to a value “0” equal to “1” subtracted by “1”.
Subsequently, the multiplexer 145 determines whether or not a condition “j<1” in operation S405 is met. Here, since “j=0”, the condition “j<1” is met. Therefore, the multiplexer 145 performs the procedure in operation S414.
Specifically, the multiplexer 145 updates the variable j from “0” to “1”. Also, the multiplexer 145 substitutes “X(j)+1” into X(j). Here, since “j=1” and “X(1)=0”, the multiplexer 145 substitutes “0+1” into X(1). In addition, the multiplexer 145 substitutes X(j) into the variable k. Here, since “X(1)=1”, the multiplexer 145 substitutes “1” into the variable k. Also, the multiplexer 145 substitutes Z(i) into Y(j, k). Here, since “i=1”, “j=1”, “k=1”, and the work model M101 is substituted in Z(1), as illustrated in
Subsequently, the multiplexer 145 performs synchronization setting (operation S415). It should be noted that the synchronization setting performed by the multiplexer 145 will be described later with reference to
Subsequently, the multiplexer 145 determines whether or not the condition “n≦1” in operation S403 is met. Here, since “n=20”, the condition “n≦1” is not met. Therefore, the multiplexer 145 substitutes i into the variable j (operation S404). Here, since “i=2”, the multiplexer 145 substitutes “2” into the variable j.
Subsequently, the multiplexer 145 determines whether or not the condition “j<1” in operation S405 is met. Here, since “j=2”, the condition “j<1” is not met. Therefore, the multiplexer 145 substitutes X(j) into the variable k (operation S406). Here, since “j=2”, and “X(2)=0”, the multiplexer 145 substitutes “0” into the variable k.
Subsequently, the multiplexer 145 determines whether or not the condition “k<1” in operation S407 is met. Here, since “k=0”, the condition “k<1” is met. Therefore, the multiplexer 145 updates the variable j from “2” to “1” (operation S412).
Subsequently, the multiplexer 145 determines whether or not the condition “j<1” in operation S405 is met. Here, since “j=1”, the condition “j<1” is not met. Therefore, the multiplexer 145 substitutes X(j) into the variable k (operation S406). Here, since “j=1”, and “X(1)=1”, the multiplexer 145 substitutes “1” into the variable k.
Subsequently, the multiplexer 145 determines whether or not the condition “k<1” in operation S407 is met. Here, since “k=1”, the condition “k<1” is not met. Therefore, the multiplexer 145 performs multiplexing determination (operation S408). It should be noted that the multiplexing determination performed by the multiplexer 145 will be described later with reference to
If it is determined to perform multiplexing as a result of the multiplexing determination, the multiplexer 145 decrements the variable k (operation S410). On the other hand, if it is determined not to perform multiplexing, the multiplexer 145 performs the procedure in operation S414.
It should be noted that here, since the multiplexer 145 determines not to perform multiplexing, the multiplexer 145 performs the procedure in operation S414. Specifically, the multiplexer 145 updates the variable j from “1” to “2”. Also, the multiplexer 145 substitutes “X(j)+1” into X(j). Here, since “j=2” and “X(2)=0”, the multiplexer 145 substitutes “0+1” into X(2). Also, the multiplexer 145 substitutes X(j) into the variable k. Here, since “X(2)=1”, the multiplexer 145 substitutes “1” into the variable k. In addition, the multiplexer 145 substitutes Z(i) into Y(j, k). Here, since “i=2”, “j=2”, “k=1”, and the work model M102 is substituted in Z(2), as illustrated in
In this way, the multiplexer 145 performs the above-described procedure until the condition “n≦1” in operation S403 is met. Thus, as illustrated in
[Initialization Procedure]
Next, referring to
As illustrated in
Specifically, the multiplexer 145 substitutes “0” into an array X(n) and an array W(n) (operation S503). Subsequently, the multiplexer 145 decrements the variable n (operation S504). That is, the multiplexer 145 substitutes “0” into elements X(1) to X(n) of the array X(n), and elements W(1) to W(n) of the array W(n).
[Multiplexing Determination Procedure]
Next, referring to
When performing multiplexing determination, first, the multiplexer 145 substitutes the name of a table referenced or updated in the work model of Z(i) into a variable ZT(i) (operation S601). Also, the multiplexer 145 substitutes the name of a table referenced or updated in the work model of Y(j, k) into a variable YT(j, k) (operation S601).
Subsequently, the multiplexer 145 determines “not to perform multiplexing” if the work model of Z(i) is “update type” (Yes in operation S602), and ZT(i) and YT(j, k) are equal (Yes in operation S603) (operation S604).
On the other hand, the multiplexer 145 determines to “perform multiplexing” if the work model substituted in Z(i) is “update type” (Yes in operation S602), and ZT(i) and YT(j, k) are different (No in operation S603) (operation S605).
If the work model substituted in Z(i) is not “update type” (No in operation S602), the multiplexer 145 determines whether or not the work model substituted in Y(j, k) is “update type” (operation S606).
Then, if the work model substituted in Y(j, k) is “update type” (Yes in operation S606), and ZT(i) and YT(j, k) are equal (Yes in operation S607), the multiplexer 145 determines “not to perform multiplexing” (operation S608).
On the other hand, if the work model substituted in Y(j, k) is “update type” (Yes in operation S606), and ZT(i) and YT(j, k) are different (No in operation S607), the multiplexer 145 determines to “perform multiplexing” (operation S609).
Also, if the work model substituted in Y(j, k) is not “update type” (No in operation S606), the multiplexer 145 determines to “perform multiplexing” (operation S610). In this way, the multiplexer 145 determines whether or not to perform multiplexing, in accordance with the conditions illustrated in
[Synchronization Setting Procedure]
Next, referring to
As illustrated in
Then, if the variable j is smaller than “1”, the multiplexer 145 ends the processing. On the other hand, if the variable j is not smaller than “1”, the multiplexer 145 substitutes the value of X(j) into a variable k (operation S703).
Subsequently, the multiplexer 145 repeats the procedure in operations S704 to S708 until a condition “k≦1” is met. Specifically, the multiplexer 145 compares Z(i) with Y(j, k), and if Z(i) is update type and Y(j, k) is reference type, the multiplexer 145 determines that synchronization setting is unnecessary (operation S705). Then, the multiplexer 145 decrements the variable k (operation S706).
On the other hand, if Z(i) is not update type, or if Y(j, k) is not reference type, the multiplexer 145 determines that synchronization setting is necessary (operation S705). Then, the multiplexer 145 increments the variable j, and substitutes “1” into W(j) (operation S707).
For example, if the multiplexer 145 has performed multiplexing with respect to the work models M101 to M121 illustrated in
As described above, the scenario creating apparatus 100 according to Embodiment 1 collects messages transmitted/received between individual servers, and associates messages transmitted/received within the same transactions with each other to generate work models. Then, the scenario creating apparatus 100 sorts the generated work models in ascending order of the start time of access to the DB server 15, thereby creating a scenario. Thus, the scenario creating apparatus 100 can create a scenario that makes it possible to determine pass/fail of testing correctly.
In addition, since the scenario creating apparatus 100 according to Embodiment 1 multiplexes the work models sorted in ascending order of the start time of access to the DB server 15, it is possible to create a scenario that requires a short test execution time.
Further, since the scenario created by the scenario creating apparatus 100 has been multiplexed, the scenario can be also used for load testing. Also, since the scenario created by the scenario creating apparatus 100 retains messages transmitted/received between individual servers, when the result of test verification is NG, it is possible to identify between which servers an error has occurred. Thus, use of the scenario generated by the scenario creating apparatus 100 makes it possible to identify the location of an error with ease and in a short time.
Incidentally, the scenario creating apparatus or the like disclosed by this application may be implemented in various other modes other than the above-described embodiment. Accordingly, in Embodiment 2, another embodiment of the scenario creating apparatus or the like disclosed by this application will be described.
[Attribute of Work Model]
Embodiment 1 mentioned above illustrates an example in which, as illustrated in
For example, in a case when the current work model performs updating to Tables A, B, and C, and the immediately preceding work model performs referencing to Tables C, D, and E, the swapper 144 or the multiplexer 145 determines the “tables to be referenced/updated” by the current work model and the immediately preceding work model to be the “same”. This is because both the work models perform updating or referencing to Table C.
Also, for example, in a case when the current work model performs updating to Tables A, B, and C, and the immediately preceding work model performs referencing to Tables D and E, the swapper 144 or the multiplexer 145 determines the “tables to be referenced/updated” by the current work model and the immediately preceding work model to be “different”. This is because both the work models perform referencing or updating to tables that are all different.
[Program]
The various kinds of processing described in Embodiment 1 above can be implemented by executing a program prepared in advance by a computer such as a personal computer or a workstation. Accordingly, in the following, with reference to
In the ROM 1040, a scenario creating program that exhibits the same function as the scenario creating apparatus 100 according to Embodiment 1 mentioned above is stored in advance. Specifically, in the ROM 1040, a collection program 1041, an association program 1042, a sorting program 1043, a swapping program 1044, a multiplexing program 1045, and a scenario creating program 1046 are stored.
Then, the CPU 1050 reads the collection program 1041, the association program 1042, the sorting program 1043, the swapping program 1044, the multiplexing program 1045, and the scenario creating program 1046 to execute these programs. Thus, as illustrated in
It should be noted that the collection process 1051 corresponds to the collector 141 illustrated in
As illustrated in
It should be noted that the programs 1041 to 1046 mentioned above may not necessarily be stored in the ROM 1040. For example, the programs 1041 to 1046 may be stored on a “portable physical medium” inserted into the computer 1000, such as a flexible disc (FD), a CD-ROM, an MO disc, a DVD disc, a magneto-optical disc, and an IC card. Alternatively, the programs 1041 to 1046 may be stored on a “stationary physical medium” provided inside or outside the computer 1000, such as a hard disk drive (HDD). Alternatively, the programs 1041 to 1046 may be stored on “another computer (or server)” connected to the computer 1000 via a public circuit, the Internet, the LAN, the WAN, or the like. Then, the computer 1000 may execute the programs by reading the programs from the flexible disc or the like mentioned above.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the principles of the invention and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although the embodiment(s) of the present invention(s) has(have) been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
Although a few preferred embodiments of the present invention have been shown and described, it would be appreciated by those skilled in the art that changes may be made in these embodiments without departing from the principles and spirit of the invention, the scope of which is defined in the claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
2009-132957 | Jun 2009 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
4803683 | Mori et al. | Feb 1989 | A |
6351826 | Kato | Feb 2002 | B1 |
6657641 | Tachibana et al. | Dec 2003 | B2 |
6988208 | Hrabik et al. | Jan 2006 | B2 |
7644307 | Musoll | Jan 2010 | B2 |
7996723 | Levine et al. | Aug 2011 | B2 |
20020178383 | Hrabik et al. | Nov 2002 | A1 |
20050289231 | Harada et al. | Dec 2005 | A1 |
20060265416 | Seki et al. | Nov 2006 | A1 |
20070228149 | Seki et al. | Oct 2007 | A1 |
20070288226 | Higeta et al. | Dec 2007 | A1 |
20080151760 | Michl | Jun 2008 | A1 |
20090113244 | Doshi et al. | Apr 2009 | A1 |
20110030059 | Greenwald | Feb 2011 | A1 |
Number | Date | Country |
---|---|---|
11-177655 | Jul 1999 | JP |
11-184900 | Jul 1999 | JP |
2006-11683 | Jan 2006 | JP |
2006-323471 | Nov 2006 | JP |
2007-264810 | Oct 2007 | JP |
2007-272693 | Oct 2007 | JP |
Number | Date | Country | |
---|---|---|---|
20100306595 A1 | Dec 2010 | US |