AI-generated Key Takeaways
- 
          This project is a reference implementation of the API v3 Booking Server for Standard Integration using Node.js. 
- 
          It requires Node.js to be installed and uses standard Node.js features for simplicity. 
- 
          The implementation consists of two JavaScript files: bookingserver.js and apiv3methods.js. 
- 
          You can test your Booking Server using the provided Booking test utility with your credentials and an Availability feed. 
This is a reference implementation of API v3 Booking Server for Standard Integration based on Node.js
Prerequisites
Requires an installation of
Getting Started
The Booking Server is implemented using standard Node.js without any additional libraries or frameworks, for illustration purposes. If you are using any other frameworks, you could easily change this implementation to Express.js, MEAN.js, or any other Node.js-based framework of your choice.
The implementation is also not using protocol buffer libraries, but instead relies on simple JSON serialization and its JSON.parse() and JSON.stringify() methods.
To download the project, execute the following command:
git clone https://maps-booking.googlesource.com/js-maps-booking-rest-server-v3-skeleton
The entire code base consists of only two JavaScript files:
- bookingserver.js - HTTP server and requests handling logic, including authentication
- apiv3methods.js - methods implementing API v3 interface
After you download the files, you can start the Booking Server by running the command:
node bookingserver.js
The skeleton writes all incoming and outgoing requests to the console, so you can monitor its execution for tracing purposes.
Should you need an IDE for code changes or debugging, you can use Visual Studio Code or any other editor of your choice. Debug the project by starting bookingserver.js in the Node.js environment and set breakpoints where needed.
Testing your Booking Server
Download Booking test utility. To install it, follow the provided installation instructions in its README page.
For the tests, you need to create a text file to store your credentials. Enter your username and password on a single line, for example, in a file named cred.txt:
username:password
You also need a local copy of an Availability feed for your test merchants. In the samples commands below, the Availability feed is avail.json.
Now, you can test your Booking Server with these commands:
- Test calls to HealthCheck method:
bin/bookingClient -server_addr="localhost:8080" -health_check_test=true -credentials_file="./cred.txt" 
- Test calls to CheckAvailability method:
bin/bookingClient -server_addr="localhost:8080" -check_availability_test=true -availability_feed="./avail.json" -credentials_file="./cred.txt" 
- Test calls to CreateBooking and UpdateBooking methods:
bin/bookingClient -server_addr="localhost:8080" -booking_test=true -availability_feed="./avail.json" -credentials_file="./cred.txt" 
As you are implementing your own Booking Server, you may need to run additional tests against it (e.g. list_bookings_test, rescheduling_test, etc) with the goal of all tests passing (-all_tests=true).