In this section, you'll learn how to create test data using requests, test the backend with API requests, and validate the application's functionality via the UI.
As explained in the Setup and Deploy section, after configuring the UAA details from the Service Key of the genai-semantic-search-sample-uaa
instance, you can test the backend by sending requests. Use as reference: api/test/requests.sample.http
Run this command in the root folder:
npm run watch
If you are working in Visual Studio Code, install the REST Client extension; otherwise, you can use Postman to send the requests.
To access the API securely, you'll need to obtain an authentication token. Use this POST request to retrieve the token:
### GET XSUAA TOKEN
# @name getXsuaaToken
POST {{xsuaaHostname}}/oauth/token
Accept: application/json
Content-Type: application/x-www-form-urlencoded
Authorization: Basic {{btpXsuaaClient}}:{{btpXsuaaSecret}}
client_id={{btpXsuaaClient}}
&client_secret={{btpXsuaaSecret}}
&grant_type=client_credentials
After obtaining the token, use it to make an authorized request to fetch documents. Even if there are no documents initially, this test will verify that the backend is operational.
### FETCH DOCUMENTS
# @name fetchDocuments
GET {{btpAppHostname}}/odata/v4/sample/Documents
Authorization: Bearer {{token}}
To be able to test, it is necessary to have data in the database instance. To create test data using the schema defined in Data Model, use as reference this POST request in the requests.http file:
### CREATE DATA AND CALCULATE EMBEDDINGS FOR THE "Text" ATTRIBUTE
# @name embed1
POST {{btpAppHostname}}/odata/v4/sample/embed
content-type: application/json
Authorization: Bearer {{token}}
{
"data": "{\"text\":\"Artificial Intelligence (AI) has seamlessly integrated into our daily routines, from smart assistants to personalized recommendations. This article explores how AI has transformed everyday life.\", \"title\":\"AI Everyday: The Integration of Artificial Intelligence into Daily Life\", \"author\":\"Megan Lee\", \"date\":\"2018-07-12\", \"summary\":\"An overview of how artificial intelligence has become a fundamental part of our daily routines, improving efficiency and personalization.\", \"category\":\"Technology\", \"tags\":[\"AI\", \"technology\", \"daily life\", \"smart technology\"], \"language\":\"EN\", \"publication\":\"Tech Today\", \"rights\":\"All rights reserved.\"}"
}
In order to confirm that you have the created data, you can either send the fetch request again and confirm there are documents retrieved or use the SAP Database Explorer tool. You can access it within your SAP HANA Cloud instance in SAP BTP Cockpit by navigating to the instance where your data is stored. In the 'Actions' column, click the three dots and select "Open in SAP HANA Database Explorer".
Once you have verified that the corresponding table contains data, you can test the search request:
### SEARCH
# @name search
POST {{btpAppHostname}}/odata/v4/sample/search
content-type: application/json
Authorization: Bearer {{token}}
{
"snippets": ["Looking for tech related documents"]
}
For creating larger datasets you might use other tools to create random data sets such as:
These samples requests are included in api/test/requests.sample.http which you have duplicated and renamed as requests.sample.http as explained in Development section of the reference project.
After confirming that the backend is functioning and test data has been created you can test the interaction with the UI.
ℹ️ Note After executing 'npm run watch', the URL http://localhost:8080/index.html will be opened in the browser. Change the port manually to '5000' to avoid an authorization error.
- Access the application through the URL
http://localhost:5000/index.html
The application will load and display a page featuring a search bar:
2. Perform a semantic search:
- Search for documents related to topics such as "AI," "Health," "Science," "Technology," "Space," and more.
- Type your desired keywords or phrases in the search bar.
Example Searches:
AI Technology
Health and Wellness
Space Exploration
Science Research
- A table displays up to 10 documents matching the search criteria.
- The table title shows the count of documents found in brackets.
- Next to the title, a tooltip containing a question mark reveals the generated SQL query used for the search.
3. Refine your search:
- You can refine the search by typing extra information into the search bar at the top.
- When executing the search again, the search text will be reformulated and displayed in the message strip.
- The table will be updated and will show the results accordingly.
4. Verify search enhancements:
- Language Extraction: Write a search in a different language, e.g., Spanish. Execute the search and check the tooltip to confirm that the WHERE clause now contains WHERE LANGUAGE='ES'.
- Date Extraction: Type "Search documents about health from last year" and verify that the WHERE clause includes the correct date range.