Notice: This Wiki is now read only and edits are no longer possible. Please see: https://gitlab.eclipse.org/eclipsefdn/helpdesk/-/wikis/Wiki-shutdown-plan for the plan.
Descriptive WSDL Smoke Test Scenarios
The smoke tests are organized into three categories: core tests, secondary rotating tests and adhoc tests. In every test run, the goal is to devote 60% of the time to core tests from which every test should be run, 30% to secondary rotating tests from which a tester can pick two or three tests making sure to cover each test at least once in a milestone, and 10% to adhoc test which can be picked randomly.
Core Tests
Every test in this category should be run in every smoke test.
Open and Close Editor
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- Open XMLExamples/PhoneBanking/PhoneBanking.wsdl and make sure you're in the design view
- Verify you can find PhoneBanking service, a square icon representing the binding and a Port Type named PhoneBanking with four operations.
File Creation & Saving
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- File -> New -> Other... -> Web Services -> WSDL to create an new WSDL file: NewWSDLFile.wsdl
- Verify the new file is created and opened in the WSDL Editor
- Right click on the canvas and select Add Service and add a new service called NewService and add a new PortType named NewPortType as well
- Save and close the editor
- Reopen the editor and verify that the NewService and NewPortType are persisted.
- File -> Save As..., and use the name NewWSDLFileSaveAs.wsdl
- Verify the NewWSDLFileSaveAs.wsdl file appear in the navigator
- In NewWSDLFileSaveAs.wsdl, add a new service and a new PortType
- Close the editor without saving the changes
- Reopen the NewWSDLFileSaveAs.wsdl, and verify that the new changes are discarded
Selection Tests
Synchronization between Properties, Design, Source, and Outline views: while conducting the Add/Modify tests, delete tests, and drag & drop tests, observe that these three views are synchronized
Note: if the nodes are collapsed and you add a new child, the node will not automatically expand. Therefore to test synchronization, expand the nodes whenever necessary to verify the synchronization between the Outline and Design view
Add/Modify Tests
For the tests where a new item is added:
- Verify that the item was successfully added by finding and selecting the item from the Outline view or Design view
- Whenever possible, modify the name of the item by changing the Name property in the Properties view under General properties
Tests:
- Imports: in the Outline view, right click on the Imports node -> Add Import
- Schema: in the Outline view, right click on the Types node -> Add Schema
- Service: in the Outline view, right click on the Services node -> Add Service
- Port: in the Outline view, right click on a created Service -> Add Port -> add a name or use default -> click Finish
- Binding: in the Outline view, right click on the Binding node -> Add Binding
- Binding content: in the Outline view, right click on a created Binding -> Generate Binding Content... -> select a Port type and protocol -> press Finish. In the Design view, an arrow from the binding to a portType should be created
- Port Type: in the Outline view, right click on the Port Type node -> Add Port Type
- Operation: in the Outline view, select a created Port Type and right click -> Add Operation
- Fault: in the Outline view, select a created Operation (Operations are found in Port Type -> a created Port Type -> Operation) -> Add Fault
- Message via Port Type: in the Outline view, select a created Port Type and expand the node until you see two blue arrows representing Input and Output. Right click on the blue arrow pointing right -> Set Message -> New Message... The newly created message will show up in the Messages node. Right click on the blue arrow pointing left -> Set Message -> Existing Message... -> Choose an existing message -> in the Properties view under General properties, the Message property should match the message you chose
- Message: in the Outline view, right click on the Messages node -> Add Message
- Part: in the Outline view, right click on a created Message -> Add Part
- Repeat the same steps for Design View. The UI element to mouseover and right click for each test is highlighted when selected in the Outline view
Delete Tests
For each of the items created in the Add/Modify test, right click on the item or an equivalent item -> Delete
Search & Refactoring
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- Open XMLExamples/PhoneBanking/PhoneBanking.wsdl
- In the Outline view, right click Port Type -> PhoneBanking and select References -> Project
- Verify that there is one reference in PhoneBanking.wsdl
- Right click Port Type -> PhoneBanking again and select Refactor -> Rename...'
- Check Update references and change the name to PhoneBankingChanged and click Preview ->
- Verify that there are two changes in PhoneBanking.wsdl
- Click OK and verify that the changes in the preview are applied to the file using the editor. (Hint: can search for PhoneBankingChanged in the file.)
Validation
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- Open XMLExamples/PhoneBanking/PhoneBanking.wsdl and switch to source view
- Replace <wsdl:portType name="PhoneBanking"> with <wsdl:portType name="PhoneBankingChanged">
- Right click on the WSDL file in the Package Explorer and select Validate
- Verify that a red X should show up because the WSDL file is invalid
- Revert the changes and re-validate
- Verify that the X disappears
Secondary Rotating Tests
Two or three tests from this category should be run in every smoke test. Testers should make sure every test should be run at least once in any given milestone.
Drag & Drop
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- Open XMLExamples/PhoneBanking/PhoneBanking.wsdl and make sure you're in the design view
- Locate the PhoneBanking PortType and its getAccountSummary operation
- Verify you can drag & drop to re-order the input and output of the operation
- Save and reopen the file
- Verify that the changes are persisted
Source Editing
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- Open XMLExamples/PhoneBanking/PhoneBanking.wsdl and switch to the source view
- Go the this line <soap:body use="literal" /> and change it to <soap:body use="literalChanged" />
- Verify that red squiggles underline "literalChanged" (no red squiggles see https://bugs.eclipse.org/bugs/show_bug.cgi?id=124911)
- Move the cursor before <wsdl:types> and hit Ctrl + space
- Verify that you see content assist like
- Move the cursor after <wsdl:binding name="PhoneBankingSOAP" type="tns:PhoneBanking">
- Verify that you see content assist like
- Try content assist in various places if you're familiar with WSDL
- Add the following code snippet to as a child of <wsdl:definitions> (i.e. the document root)
<wsdl:service name="NewService"> <wsdl:port name="NewPort"> <soap:address location="http://www.example.org/" /> </wsdl:port> </wsdl:service>
- Switch to the design view
- Verify that the NewService is visible on the canvas
- Add a new binding in design view by using right click -> Add Binding
- Switch back to the source view
- Verify that you can find <wsdl:binding name="NewBinding"></wsdl:binding>
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- Open XMLExamples/PhoneBanking/PhoneBanking.wsdl and switch to the source view
- Go the this line <wsdl:port binding="tns:PhoneBankingSOAP" name="PhoneBankingSOAP">
- Hold Ctrl and click on "tns:PhoneBankingSOAP"
- Verify that the source editor "jumps" to this line <wsdl:binding name="PhoneBankingSOAP" type="tns:PhoneBanking">
Extensions
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- Open XMLExamples/PhoneBanking/PhoneBanking.wsdl and make sure you're in the design view
- In the Outline view, right click Bindings -> PhoneBankingSOAP and select Show properties
- Click on the Extensions tab
- Verify that you can see the soap:binding extension
- Click Add...
- Select HTTP and then select binding and click OK
- Verify that an extension p:binding is added where p is defined in the source view as xmlns:p="http://schemas.xmlsoap.org/wsdl/http/"
- Fill in the Extension Details like required="true" and verb="abc"
- Save and reopen the file
- Verify the newly added extension is persisted
- Delete the p:binding extension
- Verify the extension is deleted
Schemas
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- Open XMLExamples/PhoneBanking/PhoneBanking.wsdl and make sure you're in the design view
- Hover your mouse over the arrow next to BillInfo
- Verify a schema preview popup shows up
- Click on the canvas to close the popup (Note: if this doesn't close it, click on the popup to close it.)
- Click on the arrow next to BillInfo
- Verify an external Schema Editor is opened on the file PhoneBanking.xsd showing the BillInfo
- Go back to the WSDL Editor of PhoneBanking.wsdl
- Right click on the PortType PhoneBanking and select Add Operation
- Click one of the faded gray arrows that appears on the right side of the new Operation
- Verify that an external Schema Editor is opened and its title says Inline Schema of PhoneBanking.wsdl
Preferences
- Go to Window -> Preferences -> Web Services -> WSDL Files
- In Default Target Namespace, set it to http://myDefaultTNS
- Create a new WSDL file named NewWSDLFile.wsdl using File -> New -> Other... -> Web Services -> WSDL
- Verify that you can find this attribute targetNamespace="http://myDefaultTNS/NewWSDLFile/" in the <wsdl:definitions> tag
WS-I Compliance
- Import the XML Examples: New -> Example ... -> Editing and validating XML files
- Open XMLExamples/PhoneBanking/PhoneBanking.wsdl
- Create a new WSDL file using the following content:
<?xml version="1.0" encoding="UTF-8"?> <wsdl:definitions name="WSIComplianceWSDL" targetNamespace="http://www.example.org/WSIComplianceWSDL/" xmlns:wsdl="http://schemas.xmlsoap.org/wsdl/" xmlns:tns="http://www.example.org/WSIComplianceWSDL/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:http="http://schemas.xmlsoap.org/wsdl/http/"> <wsdl:types> <xsd:schema xmlns:xsd="http://www.w3.org/2001/XMLSchema" targetNamespace="http://www.example.org/WSIComplianceWSDL/"> <xsd:element name="NewOperation"> <xsd:complexType> <xsd:sequence> <xsd:element name="in" type="xsd:string"></xsd:element> </xsd:sequence> </xsd:complexType> </xsd:element> <xsd:element name="NewOperationResponse"> <xsd:complexType> <xsd:sequence> <xsd:element name="out" type="xsd:string"></xsd:element> </xsd:sequence> </xsd:complexType> </xsd:element> </xsd:schema> </wsdl:types> <wsdl:message name="NewOperationRequest"> <wsdl:part name="parameters" element="tns:NewOperation"></wsdl:part> </wsdl:message> <wsdl:message name="NewOperationResponse"> <wsdl:part name="parameters" element="tns:NewOperationResponse"></wsdl:part> </wsdl:message> <wsdl:portType name="NewPortType"> <wsdl:operation name="NewOperation"> <wsdl:input message="tns:NewOperationRequest"></wsdl:input> <wsdl:output message="tns:NewOperationResponse"></wsdl:output> </wsdl:operation> </wsdl:portType> <wsdl:binding name="NewBinding" type="tns:NewPortType"> <http:binding verb="GET" /> <wsdl:operation name="NewOperation"> <http:operation location="/NewOperation" /> <wsdl:input> <http:urlEncoded /> </wsdl:input> </wsdl:operation> </wsdl:binding> <wsdl:service name="NewService"> <wsdl:port name="NewPort" binding="tns:NewBinding"> <http:address location="http://www.example.org/"/> </wsdl:port> </wsdl:service> </wsdl:definitions>
- Go to Window -> Preferences -> Service Policies
- Set the Compliance Level to Ignore compliance for both WSI AP 1.0 and WSI BP 1.1 SSBP 1.0
- Validate the WSDL file, and verify no WS-I warnings appear
- Change the Compliance Level to Suggest compliance
- Validate the WSDL file again, and verify there are WS-I warnings
- Change the Compliance Level to Require compliance
- Validate the WSDL file again, and verify there are WS-I errors
Adhoc Tests
Please go to Full WSDL Function Test Scenarios and randomly pick some tests that are not in neither the core tests nor the secondary rotating tests.