Skip to content

JoelChambers/gsx-mockserver

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Introduction

gsx-mockserver is a mock version of the GSX SOAP API. It can be used for testing your GSX integration code or hosting demo environments, for example allowing you to test GSX-API functionality even if you don't have the necessary SSL certificates and firewall whitelistings for GSX access.

The mock responses are collected from example XML snippets in Apple's API documentation and is therefore by no means exhaustive and 1:1 accurate, but it's definitely better than nothing and much faster to develop against than using the actual API test environments.

Installation

The server requires Python 3 and has only one external dependency - lxml which is used to parse the request XML.

$ pip install lxml
$ python serve.py
Validating XML responses...
GSX mock server serving on http://localhost:8080

You can also specify the port and address to serve on with the -p and -a arguments - check -h for the details. Use the GSX_THROTTLE=X environment variable to add a X-second delay to each API response.

Usage

Simply point your GSX client code to the server you just started. The most traight-forward method would probably be to replace the API URL in your code.

If you're using py-gsxws, then you can simply point your GSX client to use the mock server by setting the GSX_URL environment variable to the URL of the mock server:

GSX_URL=http://localhost:8080 python my_gsx_code_using_pygsxws.py

Variable reflection

The server will automatically replace values in the response with corresponding values in the request meaning if you have <serialNumber>lalalala</serialNumber> in your request, the <serialNumber> in the response will also be lalalala.

For variables that have different names in requests and responses (like dispatchId vs repairConfirmationNumber) you can also use Python's string templates in the response files themselves. In this case a request like this:

<MarkRepairCompleteRequest>
    <userSession>
        <userSessionId>Sdt7tXp2XytTEVwHBeDx6lHTXI3w9s+M</userSessionId>
    </userSession>
    <repairConfirmationNumbers>LALALALALA</repairConfirmationNumbers>
    <dispatchId>123456</dispatchId>
    </MarkRepairCompleteRequest>
</asp:MarkRepairComplete>

And a response template like this:

<MarkRepairCompleteResponse>
    <operationId>ykNJV0zy368v5uqnUYthI63zNSeip8/J</operationId>
        <repairConfirmationNumbers>
            <repairConfirmationNumber>$dispatchId</repairConfirmationNumber>
             <outcome>STOP/HOLD</outcome>
               <messages>Some Message1</messages>
               <messages>Some Message2</messages>
        </repairConfirmationNumbers>
        <repairConfirmationNumbers>
               <repairConfirmationNumber>$dispatchId</repairConfirmationNumber>
               <outcome>HOLD</outcome>
               <messages>Some Message1</messages>
               <messages>Some Message2</messages>
        </repairConfirmationNumbers>
        <repairConfirmationNumbers>
               <repairConfirmationNumber>$dispatchId</repairConfirmationNumber>
               <outcome>HOLD</outcome>
               <messages>Some Message1</messages>
               <messages>Some Message2</messages>
    </repairConfirmationNumbers>
</MarkRepairCompleteResponse>$dispatchId</repairConfirmationNumber>

... would result in the following response:

<MarkRepairCompleteResponse>
    <operationId>ykNJV0zy368v5uqnUYthI63zNSeip8/J</operationId>
        <repairConfirmationNumbers>
            <repairConfirmationNumber>123456</repairConfirmationNumber>
             <outcome>STOP/HOLD</outcome>
               <messages>Some Message1</messages>
               <messages>Some Message2</messages>
           </repairConfirmationNumbers>
           <repairConfirmationNumbers>
               <repairConfirmationNumber>123456</repairConfirmationNumber>
               <outcome>HOLD</outcome>
               <messages>Some Message1</messages>
               <messages>Some Message2</messages>
           </repairConfirmationNumbers>
           <repairConfirmationNumbers>
               <repairConfirmationNumber>123456</repairConfirmationNumber>
               <outcome>HOLD</outcome>
               <messages>Some Message1</messages>
               <messages>Some Message2</messages>
    </repairConfirmationNumbers>
</MarkRepairCompleteResponse>123456</repairConfirmationNumber>

Please note that due to inconsistencies in the response schema, this feature doesn't work with every request type.

Development

If you run into an API call that the mock server cannot handle (resulting in a 404 response), just go to the API docs, find the example XML for the relevant call and copy/paste it into responses/$SOAPAction.xml where $SOAPAction equals the value of the SOAPActionheader of the sent request (excluding the double quotes, for example Authenticate, MarkRepairComplete, UpdateCarryIn, etc)

About

Mock SOAP server for the GSX web API

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages