Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

QA: Jan 0.5.9 Release Sign-off #4055

Closed
imtuyethan opened this issue Nov 20, 2024 · 26 comments
Closed

QA: Jan 0.5.9 Release Sign-off #4055

imtuyethan opened this issue Nov 20, 2024 · 26 comments
Assignees
Labels
QA For tracking QA processes and initiatives
Milestone

Comments

@imtuyethan
Copy link
Contributor

imtuyethan commented Nov 20, 2024

Regression Test Checklist

Get original QA checklist here: https://hackmd.io/@janhq/SJO9kXpJ1x
Release Version: v0.5.9


A. Installation, Update, and Uninstallation

1. Users Install App (New User Flow)

  • Installation package passes all security checks.
  • App launches successfully after installation.

2. Users Update App (Existing User Flow)

  • Validate that the update does not corrupt user data or settings.
  • App restarts or prompts the user to restart after an update.
  • Ensure the /models directory has any JSON/YML files that change according to the update.
  • Updating the app also updates extensions' versions correctly.
  • The bottom bar displays the correct app status when updating.

3. Users Uninstall / Close App

  • After closing the app, confirm that all models are unloaded.
  • Ensure the uninstallation process removes the app from the system completely.
  • Verify that the app recreates all necessary folders (models, extensions) after reopening post-uninstallation.

Testing Script:

1. Users Install App (New User Flow)

a. Installation Package Security Check
	•	Test: Download the installation package from https://github.com/janhq/jan/releases
	•	Before running, check if the package is flagged by any system security features (e.g., macOS Gatekeeper, Windows SmartScreen, antivirus software).
	•	Expected Behavior: The system should not display any warnings, and the installation package should pass all security checks without errors.

b. App Launch
	•	Test: Run the installation process and attempt to launch the app after the installation is complete.
	•	Steps:
	1.	Double-click the installation package and follow the on-screen instructions to install the app.
	2.	After the installation completes, locate the app in the Applications folder (macOS) or Start Menu (Windows).
	3.	Launch the app.
	•	Expected Behavior: The app should launch successfully and display the home screen without any crashes or errors.
	•	Verify: Ensure that all necessary folders (e.g., /models, /extensions) are created during the first launch.

2. Users Update App (Existing User Flow)

a. Validate Data Integrity
	•	Test: Update the app without corrupting user data or settings.
	•	Steps:
	1.	Open the current version of the app and verify that all models and settings are intact.
	2.	Download the latest update and run the update process.
	3.	After the update, reopen the app and check if all models, settings, and extensions are preserved.
	•	Expected Behavior: The app should update without corrupting any user data or settings, and previously saved settings should be intact.
        •.      Test: Ensure the bottom status bar displays the correct update progress/status during the update process.
	•	Steps:
	1.	While running the update, observe the bottom status bar for any messages related to the progress of the update.
	2.	Check for clear communication (e.g., “Update in progress”, “Restart required”) during the update.
	•	Expected Behavior: The bottom bar should display the correct status of the update, and progress should be clearly communicated.

b. App Restart After Update
	•	Test: Confirm that the app restarts or prompts the user to restart after an update.
	•	Steps:
	1.	Once the update is completed, check if the app automatically restarts or prompts the user to manually restart.
	2.	Reopen the app after restarting to ensure the update was applied successfully.
	•	Expected Behavior: The app should either restart on its own or prompt the user to restart, and the update should be applied.

c. Models Directory Update
	•	Test: Ensure that the /models directory has the correct files (e.g., JSON/YML) according to the update.
	•	Steps:
	1.	Navigate to the /models directory in the file system.
	2.	Check if any new files (e.g., model.json, .yml) were added or modified during the update.
	•	Expected Behavior: The directory should reflect any necessary changes, and new models should have updated metadata files.

d. Extension Version Update
	•	Test: Confirm that updating the app also updates the extensions to the correct versions.
	•	Steps:
	1.	Open the Extensions section of the app after the update.
	2.	Check the version numbers of each extension and compare them with the release notes to ensure they are up to date.
	•	Expected Behavior: All core and model provider extensions should be updated to the correct versions.

3. Users Uninstall / Close App

a. Unload Models
	•	Test: Confirm that all models are unloaded when the app is closed.
	•	Steps:
	1.	Launch a model in the app and then close the application.
	2.	Reopen the app and check the model status to ensure that it was unloaded correctly.
	•	Expected Behavior: No models should remain active after the app is closed.

b. Complete Uninstallation
	•	Test: Verify that the uninstallation process removes the app completely from the system.
	•	Steps:
	1.	Use the Uninstall feature in the app or manually uninstall it from the system (e.g., move the app to the trash on macOS or use the Control Panel on Windows).
	2.	After uninstallation, check that the app folder and its related files (e.g., models, logs) have been deleted from the system.
	•	Expected Behavior: The app and all associated files should be removed from the system.

c. App Recreates Necessary Folders
	•	Test: After uninstallation and reinstallation, verify that the app recreates all necessary folders (models, extensions).
	•	Steps:
	1.	Reinstall the app after uninstalling it.
	2.	Check that the necessary directories (e.g., /models, /extensions) are automatically recreated upon relaunch.
	•	Expected Behavior: The app should recreate all required folders during the reinstallation and first launch process.

B. Chat and Thread Functionality

1. Users Can Chat with Jan (Default Assistant)

  • Sending a message allows users to receive responses from the model.
  • Conversation thread is maintained without any loss of data upon sending multiple messages.
  • Users should be able to edit the message, and the assistant will re-generate the answer based on the edited version of the message.
  • Test for the ability to send different types of messages (e.g., text, emojis, code blocks).
  • Check the output format of the AI (code blocks, JSON, markdown, etc.).
  • Validate the scroll functionality in the chat window for lengthy conversations.
  • Users can copy or delete the response.
  • Users can import documents (RAG), and the system should process queries about the uploaded file, providing accurate and appropriate responses in the conversation thread.
  • Users can import an image, and a model with vision (e.g., LLaVA) can generate responses. #294
  • Check the clear message / delete entire chat button functionality.
  • Test the assistant's ability to maintain context over multiple exchanges within one thread.
  • Check the create new chat button and confirm that a new conversation will have an automatically generated thread title based on the user's message.
  • Ensure the app can handle changing models mid-thread without losing the conversation's context.
  • Check the regenerate button to ensure it renews the response (single/multiple times).
  • Check that Instructions are updated correctly after the user updates it midway through the conversation (mid-thread).
  • Users can switch between models if multiple are available.
  • Validate appropriate error handling and messaging if the assistant fails to respond.
    • Simulate conditions where a model might fail to load.
    • Ensure logs and instructions guide users through resolving the issue.
    • Verify the app captures hardware and log info for troubleshooting.

Testing Script:

1. Users Can Chat with Jan (Default Assistant)

a. Sending Messages

	•	Test: Send a basic message like:
Prompt: “What is the capital of France?”
	•	Expected Response: “The capital of France is Paris.”
	•	Verify: Ensure the message is sent, and a response is received from the model without any errors.

b. Conversation Thread

	•	Test: Send multiple messages consecutively:
Prompt 1: “Tell me a joke.”
Prompt 2: “What is the largest planet in the solar system?”
Expected Response: The thread should maintain all previous conversation data without losing any context between messages.
	•	Verify: Ensure there is no loss of data or context as multiple messages are sent.

c. Editing Messages

	•	Test: Send a message and then edit it:
Prompt: “What is 2 + 2?”
	•	Edit: Change the question to “What is 5 + 3?”
	•	Expected Response: The assistant should re-generate the response based on the edited version, answering “5 + 3 is 8.”
	•	Verify: Ensure that the response updates correctly after editing the original prompt.

d. Sending Different Types of Messages

	•	Test: Send various types of messages, including text, emojis, and code blocks:
Prompt:

Here is a Python code:
```python
def hello():
    return "Hello, World!"

- **Expected Response**: The assistant should correctly format and display code blocks.
- **Verify**: Ensure that emojis (e.g., 😊) and code blocks are handled appropriately.



e. Output Format

	•	Test: Ensure the assistant generates responses in different formats:
Prompt: “Generate a JSON object with name, age, and location.”
	•	Expected Response:

{
  "name": "Alice",
  "age": 30,
  "location": "New York"
}


	•	Verify: Ensure the response is structured correctly according to the requested format.

f. Scroll Functionality

	•	Test: Engage in a long conversation or ask for a lengthy response:
Prompt: “Explain in detail how photosynthesis works.”
	•	Expected Response: The answer should be long enough to require scrolling.
	•	Verify: Ensure that scrolling works correctly and all content is visible without truncation.

g. Copy/Delete Response

	•	Test: Copy and delete specific responses in the chat.
	•	Verify: Ensure that responses can be copied and deleted correctly without affecting other messages.

h. Importing Documents (RAG)

	•	Test: Import a document and ask a query related to the content of the document.
Prompt: “Please answer based on this document.”
	•	Expected Response: The system should process the query and provide accurate responses based on the uploaded file’s content.

i. Importing an Image (Vision Model)

	•	Test: Import an image and ask the model (e.g., LLaVA) to generate a response:
Prompt: “Describe what is in this image.”
	•	Expected Response: The model should generate a description of the image.
	•	Verify: Ensure the model with vision capabilities responds accurately based on the uploaded image.

j. Clear/Delete Chat

	•	Test: Use the clear message / delete entire chat options.
	•	Verify: Ensure that these actions are successful and do not affect the model instructions or settings.

k. Context Over Multiple Exchanges

	•	Test: Engage in multiple exchanges within the same thread:
Prompt 1: “Who was Albert Einstein?”
Prompt 2: “What is the theory of relativity?”
	•	Expected Response: The assistant should maintain context between exchanges and refer to previous responses when relevant.

l. Create New Chat

	•	Test: Use the create new chat button and start a fresh conversation.
	•	Prompt: “What is the weather like today?”
	•	Expected Response: The conversation should start as a new thread, and the title should automatically generate based on the user’s message.
	•	Verify: Ensure that the previous conversation context is not carried over into the new chat.

m. Model Switching Mid-Thread

	•	Test: Switch models mid-thread and ask for another response.
Prompt: “Can you write a haiku?”
	•	Expected Response: The app should handle switching models and generate a response from the newly selected model without losing conversation context.

n. Regenerate Response

	•	Test: Use the regenerate button to regenerate the assistant’s response.
Prompt: “Tell me something about space exploration.”
	•	Expected Response: A new response should be generated upon clicking the regenerate button.
	•	Verify: Ensure that the regenerate button works multiple times if needed.

o. Instructions Update

	•	Test: Update the instructions for the assistant midway through a conversation.
Prompt: Update the instruction to “Give concise answers” and ask:
Prompt: “What is quantum computing?”
	•	Expected Response: The response should be concise, reflecting the updated instructions.
	•	Verify: Ensure that the instruction update is applied immediately.

p. Error Handling

	•	Test: Simulate conditions where a model might fail to load (e.g., disconnect network temporarily).
	•	Expected Behavior: Logs and instructions should guide users through the issue.
	•	Verify: Ensure the app captures hardware information and logs for troubleshooting.

2. Model Display & Handling

  • Models in Model Selection should highlight recommended models based on user RAM (this is likely based on a static formula).
  • Models in Model Selection should be grouped correctly.
  • The bottom bar displays the correct status when downloading models.
  • Threads display the correct status for models
    - Start models
    - Model started successfully
    - Generate response
    - Stopping models
    - Models fail to start

Testing Script:

1. Model Selection Highlight for Recommended Models Based on User RAM

	•	Test: Verify that models are highlighted as “Recommended” based on the user’s available RAM.
	•	Steps:
	1.	Open the Model Selection dropdown.
	2.	Look for any models labeled with a warning about insufficient RAM or marked as “Recommended” based on your device’s memory.
	3.	Confirm if the recommendation matches your system specifications.
	•	Expected Behavior: Models that are suitable for your system RAM should be highlighted, and those exceeding the system’s capacity should show warnings (e.g., “Slow on your device”).

2. Thread Status for Models

	•	Test: Ensure that threads display the correct model status, including starting, stopping, or failing to start a model.
	•	Steps:
	1.	Start a conversation with a model in a new thread.
	2.	Change models mid-conversation by selecting a different model from the Model Selection dropdown.
	3.	Test starting, stopping, and switching models to check the status messages.
	•	Expected Behavior: The thread should show the following statuses correctly:
	•	“Starting Model…”
	•	“Model Started Successfully”
	•	“Stopping Model…”
	•	Any error messages for models failing to start or run.

3. Users Can Customize Thread Settings

  • Instructions set by the user are followed by the assistant in subsequent conversations. Changes to instructions are updated in real time and do not require a restart of the application or session.
  • Ability to reset instructions to default or clear them completely.
  • Adjust model parameters (e.g., Temperature, Top K, Top P) from the GUI and verify they are reflected in the chat behavior.
  • Check the maximum and minimum limits of adjustable parameters and how they affect the assistant's responses.
  • Changes can be saved and persisted between sessions.
  • Users can access and modify the model.yml file.
  • Changes made in model.yml are correctly applied to the chat session upon reload or restart.

Testing Script:

a. Temperature

	•	Purpose: Controls the randomness of the model’s responses.
	•	Test:
	•	Set temperature to 0.2 and ask a factual question:
Prompt: “What is the capital of France?”
Expected: “The capital of France is Paris.”
	•	Set temperature to 0.9 and ask a creative prompt:
Prompt: “What is the capital of France?”
Expected: A more varied, creative response. E.g, "The capital of France is actually Paris, not Rome. Rome is the capital of Italy."



b. Top P (Nucleus Sampling)

	•	Purpose: Controls the probability mass of tokens considered for responses.
	•	Test:
	•	Set Top P to 0.95 and ask:
Prompt: “What is artificial intelligence?”
Expected: A detailed and varied response.
	•	Set Top P to 0.5 and ask the same question.
Expected: A more concise, deterministic answer.

c. Stream

	•	Purpose: Enables streaming of tokens as they are generated.
	•	Test:
	•	Turn Stream ON and ask a long-form question:
Prompt: “Explain how solar panels convert sunlight into electricity.”
Expected: The response is streamed token by token.
	•	Turn Stream OFF and ask the same question.
Expected: The full response appears after it’s fully generated.

d. Max Tokens

	•	Purpose: Limits the maximum number of tokens the model can generate.
	•	Test:
	•	Set Max Tokens to 100 and ask a detailed question:
Prompt: “Can you explain the process of photosynthesis?”
Expected: A shorter, more concise response.
	•	Increase Max Tokens to 400 and ask the same question.
Expected: A more detailed, longer explanation.

e. Frequency Penalty

	•	Purpose: Discourages word repetition by applying penalties.
	•	Test:
	•	Set Frequency Penalty to 0 and ask:
Prompt: “Explain why repetition is important in learning.”
Expected: Some repetition may occur.
	•	Set Frequency Penalty to 1 and ask the same question.
Expected: Minimal or no repetition.

f. Presence Penalty

	•	Purpose: Encourages introducing new ideas into the response.
	•	Test:
	•	Set Presence Penalty to 0 and ask:
Prompt: “Describe a typical day in your life.”
Expected: Similar topics may repeat.
	•	Set Presence Penalty to 1 and ask the same question.
Expected: More varied content with fewer repeated ideas.

g. Model Settings (Prompt Template)

	•	Purpose: Customize the structure of the prompt given to the model.
	•	Test:
	•	Modify the Prompt Template with a system message:
Template:
 You are a friendly assistant. 
{prompt}
Prompt: “What is quantum computing?”
Expected: A friendly, concise answer following the system message.

h. Context Length

	•	Purpose: Controls how much conversation context the model retains.
	•	Test:
	•	Set Context Length to 128 and engage in a multi-turn conversation.
Expected: The model loses track of earlier parts of the conversation.
	•	Set Context Length to 4096 and repeat the conversation.
Expected: The model retains and references earlier parts more effectively.

i. GPU Layers

	•	Purpose: Controls how many layers of the model run on the GPU for faster processing.
	•	Test:
	•	Set GPU Layers to 1 and ask a complex question.
Expected: Slower response due to minimal GPU acceleration.
	•	Set GPU Layers to 29 and ask the same question.
Expected: Faster response with higher GPU utilization.

4. Users Can Click on a History Thread

  • Chat window displays the entire conversation from the selected history thread without any missing messages.
  • Historical threads reflect the exact state of the chat at that time, including settings.
  • Ability to delete or clean old threads.
  • Changing the title of the thread updates correctly.

Testing Script

1. Historical Thread Reflects Correct State

	•	Test: Confirm that historical threads reflect the exact state of the chat, including settings such as model choice, parameters, or system settings, as they were during the conversation.
	•	Steps:
	1.	Start a conversation using a specific model (e.g., Mistral 7B).
	2.	Adjust settings like temperature or tokens and save the conversation.
	3.	Open the saved conversation from history and verify if the settings match what was used at the time.
	•	Expected Behavior: The model, parameters, and settings should be exactly as they were when the conversation occurred.

2. Delete or Clean Threads

	•	Test: Use the option to delete or clean old threads from the history list.
	•	Steps:
	1.	Select an old thread from the sidebar.
	2.	Use the delete option (e.g., trash icon) to remove the thread.
	3.	Verify that the thread is removed from both the sidebar and the conversation history.
	•	Expected Behavior: The thread should be permanently deleted, and no residual data should be available after deletion.

3. Change Title of a Thread

	•	Test: Change the title of a conversation thread and ensure the title updates correctly.
	•	Steps:
	1.	Select a thread from the sidebar.
	2.	Use the rename option (if available) to modify the title of the thread.
	3.	Confirm that the new title is updated both in the sidebar and within the chat window.
	•	Expected Behavior: The new title should be reflected correctly, and the change should be applied without affecting the content of the thread.

C. Hub

1. Users Can Discover Recommended Models

  • Each model's recommendations are consistent with the user’s activity and preferences.
  • Search models and verify results/actions on the results.

2. Users Can Download Models Suitable for Their Devices

  • Model list should be in order: Local models > Remote models
  • Ensure that models are labeled with RAM requirements tags are displayed correctly based on the user's hardware.
  • Ensure each model has full information.
  • Check the download model functionality and validate if the cancel download feature works correctly.
  • Click Use button to use the model. Expect to jump to the thread and see the model in the dropdown model selector.

3. Users Can Import Models via a HuggingFace URL

  • Import via Hugging Face ID/full HuggingFace URL, and check the progress bar reflects the download process.
  • Test deep-link import. #2876
  • Users can use/remove the imported model.

Testing Script

	•	Test: Import a model using a Hugging Face URL.
	•	Example URL 1:

https://huggingface.co/hugging-quants/Llama-3.2-3B-Instruct-Q8_0-GGUF


	•	Example URL 2:

https://huggingface.co/city96/FLUX.1-schnell-gguf


	•	Expected Behavior: The model should begin downloading, and the progress bar should reflect the download process.
	•	Verify: Ensure the model appears in the list with the correct size and is marked as Inactive after the download completes.

4. Users Can Import New Models to the Hub

  • Ensure import works successfully via drag/drop or GGUF file upload.
  • Verify that the Move model binary file / Keep Original Files & Symlink options work correctly.
  • Users can add more info to the imported model (e.g., edit name, add information).
  • Ensure the new model updates after restarting the app.

5. Users can Integrate With a Remote Server

  • Users can click Use a remote model that they already set up in Hub

D. System Monitor

1. Users Can See Disk and RAM Utilization

  • Verify that the RAM and VRAM utilization graphs are accurately reported in real time.
  • Validate that the utilization percentages reflect the actual usage compared to the system's total available resources.
  • Ensure that the system monitors update dynamically as the models run and stop.

2. Users Can Start and Stop Models Based on System Health

  • Verify the Start/Stop action for a model, ensuring the system resource usage reflects this change.
  • Confirm that any changes in model status (start/stop) are logged or reported to the user for transparency.
  • Check the functionality of App log to ensure it opens the correct folder in the system file explorer.

Testing Script:

1. Users Can See Disk and RAM Utilization

a. Verify Real-Time RAM and VRAM Utilization

   •	Test: Run a model and observe the system monitor to ensure that RAM and VRAM utilization are accurately reported in real time.
   •	Steps:
   1.	Start a model from the My Models list.
   2.	Check the System Monitor section at the bottom of the app.
   3.	Observe the CPU and Memory usage graphs.
   •	Expected Behavior: The RAM and VRAM utilization should be updated in real-time, reflecting the active model’s resource usage.

b. Validate Utilization Percentages

   •	Test: Ensure the percentages displayed for RAM and VRAM usage reflect the actual usage compared to the system’s total available resources.
   •	Steps:
   1.	Open your system’s resource monitor (e.g., Activity Monitor on macOS or Task Manager on Windows).
   2.	Compare the values displayed in the app’s system monitor with the system’s resource monitor.
   •	Expected Behavior: The percentage of RAM and VRAM used in the app should closely match the usage reported by the system’s built-in resource monitor.

c. Monitor Updates Dynamically

   •	Test: Start and stop a model and verify that the system monitor updates dynamically as the model runs and stops.
   •	Steps:
   1.	Start a model from the My Models list and observe the system monitor.
   2.	Stop the model and check if the resource usage returns to the idle state.
   •	Expected Behavior: The resource graphs (CPU, Memory) should dynamically update when models are started or stopped, accurately reflecting the change in system load.

2. Users Can Start and Stop Models Based on System Health

a. Verify Start/Stop Action for Models

   •	Test: Start and stop a model, ensuring the system monitor reflects this action accurately.
   •	Steps:
   1.	Click Start to activate a model and observe the system monitor for any changes in CPU and Memory usage.
   2.	Click Stop to deactivate the model and check if resource usage drops.
   •	Expected Behavior: Starting the model should increase resource usage, while stopping the model should return the system to idle or lower resource consumption.

b. Log Model Status Changes

   •	Test: Confirm that any changes in the model’s status (start/stop) are logged or reported to the user for transparency.
   •	Steps:
   1.	Start and stop a model while observing the App Log.
   2.	Check if there are entries for when the model starts or stops.
   •	Expected Behavior: The app should log model status changes in the App Log, clearly indicating when a model is started or stopped.

c. App Log Functionality

   •	Test: Use the App Log button to open the log folder and ensure the app logs are accessible.
   •	Steps:
   1.	Click on the App Log button in the System Monitor section.
   2.	Verify that it opens the correct folder in the system file explorer.
   3.	Check the logs for any relevant information on model performance or resource usage.
   •	Expected Behavior: The log folder should open correctly, and the logs should contain entries related to model performance and system health.

E. Local API Server

  • Verify usage of the API Reference (Swagger) for sending/receiving requests.
    • Use default server option
    • Configure and use custom server options
  • Ensure logs are correctly captured.
  • Test the server with different configurations (e.g., model settings).
  • Verify functionality of Open Logs& Clear Logs works normally.
  • Ensure that model-related functions are disabled when the local server is running.

Testing Script

1. Verify Usage of the API Reference (Swagger) for Sending/Receiving Requests

a. Use Default Server Option

	•	Test: Start the local server using the default configuration.
	•	Steps:
	1.	Open the app and navigate to the Local API Server section.
	2.	Click Start Server using the default options (e.g., 127.0.0.1:1337).
	3.	Once the server is running, open the API reference URL in a browser:
URL: http://localhost:1337/static/index.html
	4.	Use the API Reference to send a sample request (e.g., list available models).
	•	Expected Behavior: The server should start successfully, and the API Reference (Swagger) should be accessible in the browser. Requests should be processed, and valid responses should be returned.

b. Configure and Use Custom Server Options

	•	Test: Change the server options and verify the functionality.
	•	Steps:
	1.	Modify the server configuration (e.g., change the port to 1338 or adjust the API prefix).
	2.	Click Start Server and verify the server starts with the new configuration.
	3.	Open the updated API reference in a browser:
URL: http://localhost:1338/static/index.html
	4.	Send a request (e.g., retrieve assistant details) and check if the request is processed correctly.
	•	Expected Behavior: The server should start with the new configuration, and the API reference should still be accessible with the modified URL.

2. Test the Server with Different Configurations

a. Model Settings

	•	Test: Run the server with different model settings to ensure proper log capture.
	•	Steps:
	1.	Start the local server.
	2.	Open the Model section and adjust the inference parameters (e.g., change the temperature or token limit).
	3.	Send a request via the API (e.g., generate a response using the adjusted model).
	•	Expected Behavior: The server should process the request with the updated model parameters, and logs should reflect the model’s behavior with the new settings.

3. Ensure Model-Related Functions Are Disabled When the Local Server Is Running

a. Model Functionality

	•	Test: Check that model-related functions (e.g., starting/stopping models from the UI) are disabled while the local server is running.
	•	Steps:
	1.	Start the local server and navigate to the My Models section.
	2.	Try to start or stop a model.
	•	Expected Behavior: Model-related actions (start/stop) should be disabled, and the user should see a notification or indicator that models cannot be managed while the server is running.

F. Settings

1. My Models

  • Check that downloaded models are shown in My Models page & assigned to provider groups correctly.
  • Each model’s name, version, and size should be displayed accurately.
  • Check the start / stop / delete buttons to confirm they perform the expected actions.
  • Check if starting another model stops the previously running model entirely.
  • Check that when deleting a model, it will delete all the model's files from the user's computer.

Testing Script

1. Test Start/Stop/Delete Buttons

	•	Test: Verify that the Start, Stop, and Delete buttons function as expected for each model.
	•	Steps:
	1.	Click the three-dot menu for any model in the list.
	2.	Use the Start button to load the model and confirm it successfully starts.
	3.	After starting the model, click the Stop button to unload it and ensure the process completes.
	4.	Test the Delete button and confirm that the model is deleted from both the list and your system storage.
	•	Expected Behavior: The model should start, stop, and delete as expected without any errors.

2. Verify Starting Another Model Stops the Previous Model

	•	Test: Ensure that when you start a different model, the previously running model is stopped entirely.
	•	Steps:
	1.	Start a model from the My Models list.
	2.	Once the model is running, select a different model and start it.
	3.	Observe if the first model stops running before the second model starts.
	•	Expected Behavior: Starting a new model should automatically stop the previously running model without errors.

3. Check Deletion of Model Files

	•	Test: Verify that deleting a model removes all associated files from the user’s computer.
	•	Steps:
	1.	Start by deleting a model from the My Models list using the Delete button.
	2.	After deletion, check the local storage directory (e.g., the model folder location) to ensure that all model files have been removed.
	•	Expected Behavior: The model and all related files should be completely removed from the user’s local storage after deletion.

2. Appearance

  • Test the Light, Dark, and System theme settings to ensure they are functioning as expected.
  • Confirm that the application saves the theme preference and persists it across sessions.
  • Validate that all elements of the UI are compatible with the theme changes and maintain legibility and contrast.
  • Desktop app should have shadow.
  • Ensure Spell Check works.

Testing Script

1. Color Theme Selection

	•	Test: Select different color themes from the dropdown (e.g., Joi Light, Dark, etc.).
	•	Expected Behavior: The interface should immediately update to reflect the selected color theme.
	•	Verify: Ensure the theme selection persists across app restarts.

2. Interface Theme (Solid vs Translucent)

	•	Test: Toggle between Solid and Translucent options under the Interface Theme.
	•	Expected Behavior: The background should change accordingly. Solid should display a standard opaque background, while Translucent should make the background semi-transparent.
	•	Verify: Ensure the change is applied across all sections of the interface (e.g., sidebar, chat window).

3. Spell Check

	•	Test: Toggle the Spell Check option ON/OFF.
	•	Expected Behavior: When enabled, spell check should highlight misspelled words in the chat or input fields.
	•	Verify: Misspelled words should appear underlined or highlighted when Spell Check is ON. No highlighting should occur when it’s OFF.

3. Keyboard Shorcuts

  • Test all shortcut keys (Settings > Keyboard Shortcuts) to confirm they function correctly.
  • Ensure that all information about shortcut are displayed correctly.

4. Advanced Settings

Experimental Mode

  • Test the Experimental Mode toggle to ensure it works as expected.
  • When enabled, experimental features should be activated and available across the application:
    • Tools (Retrieval,...)
    • Quick Ask
    • Vulkan (on Window & Linux)

Data Folder Relocation

  • Ensure the Jan Data Folder option opens the correct folder in the system.
  • Ensure relocating the Jan Data Folder works.
  • Ensure the app functions correctly after the data folder has been relocated.

2. Proxy and SSL Certificate

  • Test downloading a model using HTTP Proxy and confirm it works according to guidelines.
  • When Ignore SSL Certificates is enabled, the app should allow self-signed or unverified certificates, which may be required for certain proxies.

3. Logs and Data Management

  • Confirm that logs older than 7 days or exceeding 1MB are cleared upon starting the app.
  • Test that Clear Logs works.
  • Validate the Reset to Factory Settings option works correctly:
    • Retain the current app data location when resetting.
    • Reset the current app data location entirely.

Testing Script

1. Experimental Mode

	•	Test: Toggle the Experimental Mode setting ON/OFF.
	•	Expected Behavior: When enabled, experimental features should be activated and available across the application.
	•	Verify: Ensure that changes are applied immediately without requiring a restart.

2. Jan Data Folder

	•	Test: Click the Jan Data Folder path and attempt to change the folder location for storing messages and user data.
	•	Expected Behavior: A dialog box should open, allowing the user to select a new directory. Once changed, the data should be stored in the newly selected folder.
	•	Verify: Ensure that the new folder location is reflected in the application and persists across restarts.

3. HTTPS Proxy

	•	Test: Enter valid proxy credentials in the HTTPS Proxy field and leave it blank to test both cases.
	•	Expected Behavior: When valid credentials are entered, the app should route network traffic through the specified proxy.
	•	Verify: Ensure that when left blank, the app reverts to the default network configuration.

4. Ignore SSL Certificates

	•	Test: Toggle the Ignore SSL Certificates option ON/OFF.
	•	Expected Behavior: When enabled, the app should allow self-signed or unverified certificates, which may be required for certain proxies.
	•	Verify: Ensure proper handling of certificates based on the setting.

5. Clear Logs

	•	Test: Click the Clear button to delete all logs from the application.
	•	Expected Behavior: All log files should be removed, and the log directory should be empty.
	•	Verify: Reopen the application and confirm that no old logs are present.

6. Reset to Factory Settings

	•	Test: Click the Reset button to restore the app to its initial state.
	•	Expected Behavior: All models, chat history, and custom settings should be erased, and the app should return to its default state.
	•	Verify: Ensure the reset is irreversible and no previous data remains after the reset is complete.

This script covers the main functionalities and settings on the Advanced Settings page, ensuring that features like proxy, data folder relocation, and factory reset work as expected. Let me know if you need any further adjustments!

4. Extensions

1. Install and Enable Extensions

  • Validate the Install Extensions process by selecting and installing a plugin file.
  • Enable/disable extensions and confirm that the UI reflects these changes.

2. Extension Group Management

1. Model Providers

Test each model provider extension to ensure it updates properly and maintains functionality:

  • Anthropic (v1.0.2):

    • Confirm that Anthropic API key works.
  • Cohere (v1.0.0):

    • Confirm that Cohere API key works.
  • Groq (v1.0.1):

    • Confirm that Grog API key works.
  • Martian (v1.0.1):

    • Confirm that Martian API key works.
  • Mistral (v1.0.1):

    • Confirm that Mistral API key works.
  • TensorRT-LLM (v0.0.3):

    • Ensure GPU acceleration is functional and outputs expected performance.
  • NVIDIA NIM (v1.0.1):

    • Confirm that NVIDIA API key works.
  • OpenAI (v1.0.2):

    • Confirm that OpenAI API key works.
  • OpenRouter (v1.0.0):

    • Confirm that OpenRouter API key works.
  • Triton-TRT-LLM (v1.0.0):

    • Confirm that Triton-TRT-LLM API key works.

2. Core Extensions

  • Model Management (v1.0.33):

    • Ensure that Hugging Face Access Token works.
  • System Monitoring (v1.0.10):

    • Ensure that Enable App Logs works.
    • Ensure that Log Cleaning Interval works.
@imtuyethan imtuyethan added the type: feature request A new feature label Nov 20, 2024
@imtuyethan imtuyethan added QA For tracking QA processes and initiatives and removed type: feature request A new feature labels Nov 20, 2024
@github-project-automation github-project-automation bot moved this to Investigating in Jan & Cortex Nov 20, 2024
@imtuyethan imtuyethan modified the milestones: v0.5.10, v0.5.9 Nov 20, 2024
@imtuyethan imtuyethan moved this from Investigating to In Progress in Jan & Cortex Nov 20, 2024
@imtuyethan imtuyethan self-assigned this Nov 20, 2024
@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

  1. Hugging Face Access Token does not work. It requires a new configuration update through cortex.cpp.
    bug: HuggingFace token set does not work #4067
    Screenshot 2024-11-21 at 12 45 09

#4068

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

  1. Somehow users could have wrong variant value due to empty string set in the settings file. Can reproduce on Linux VM instances. Probably UI implement issue, gated in feat: configure HuggingfaceToken via cortex.cpp #4068. This led to the GPU settings being enabled, but no GPU card was available. Eventually, I resorted to using the CPU -> Possibly performance degrade on CPU only mode.

image

#4068

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

  1. Relocated Jan Data Folder test failed due to a known issue, but was shifted to 0.5.10.
  • ❌ Ensure relocating the Jan Data Folder works.
  • ❌ Ensure the app functions correctly after the data folder has been relocated.

Validate the Reset to Factory Settings option works correctly:

  • ❌ Retain the current app data location when resetting.
  • ❌ Reset the current app data location entirely.

#4001

✅ Shifted to 0.5.10

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

  1. Keyboard Shortcuts

These shortcuts don’t seem to work. @urmauur
Screenshot 2024-11-21 at 15 02 31

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

  1. It should not be possible for users to create a new thread using a shortcut while the welcome screen is displayed. @urmauur
Screenshot 2024-11-21 at 15 05 52

✅ nits, shift to 0.5.10

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

  1. After downloading a local model on the Welcome screen, it should be selected by default instead of a random Remote model.
Screenshot 2024-11-21 at 15 10 58

✅ Scoped out the hotfix. Shift to 0.5.10

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

  1. The server is running, but I can still adjust the context length component. Even if the model isn’t reloaded, the slider value remains unchanged.

See the input value, it's different from the slider's value - @urmauur
Screenshot 2024-11-21 at 15 27 57

✅ Scoped out the hotfix. Shift to 0.5.10

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

  1. Requests to /v1/models/{id} don’t reach the cortex.cpp server.
Screenshot 2024-11-21 at 15 31 05

✅ Scoped out the hotfix. Shift to 0.5.10 (known issue on 0.5.8)

@louis-jan
Copy link
Contributor

  1. The API Server’s model settings don’t change - NGL 1 -> 33.
Screenshot 2024-11-21 at 15 50 41

@imtuyethan
Copy link
Contributor Author

imtuyethan commented Nov 21, 2024

Can't adjust Max Tokens on Windows (VM 116):

Screen_Recording_2024-11-21_at_3.50.46_PM.mov

Updated: Related to Phi 3 model issue.

@imtuyethan
Copy link
Contributor Author

imtuyethan commented Nov 21, 2024

@urmauur Responsive issue: Vulkan is missing its toggle when i collapse the app.
Queued for 0.5.10.

Screenshot 2024-11-21 at 4 38 10 PM

@imtuyethan
Copy link
Contributor Author

Screenshot 2024-11-21 at 4 44 06 PM

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

❌ After installing the Tensorrt-LLm extension, the models associated with it are not visible in the Model Hub.
Screenshot 2024-11-21 at 17 01 44
Screenshot 2024-11-21 at 17 02 09

✅ Fixed in #4075

@louis-jan
Copy link
Contributor

Extension Group Management

❌ Martian (v1.0.1):
❌ Mistral (v1.0.1):
Given that the keys are invalid or out of credits. We’ll find a way to test in 0.5.10

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

App Logging
❌ The clean app log interval is now only applicable for Jan app. There is also cortex.cpp log settings.

✈️ 0.5.10

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

Users should be able to edit the message, and the assistant will re-generate the answer based on the edited version of the message.

❌ Editing the sender’s message should not send the previous replaced messages. This is a legacy issue.
Image

✈️ 0.5.10

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

It seems like that a few parameters are being brought over from cortex.cpp, but they haven’t been rounded properly.
Image

✈️ 0.5.10

@louis-jan
Copy link
Contributor

louis-jan commented Nov 21, 2024

❌ The input for the top words should accept a space as a new end token. However, it currently does not accept this, resulting in the new token being merged into the previous token. For now, users have to insert back the space after finalized.
Screenshot 2024-11-21 at 17 34 52

✈️ 0.5.10

@imtuyethan
Copy link
Contributor Author

imtuyethan commented Nov 21, 2024

@urmauur Can't open right sidebar:

Screen.Recording.2024-11-21.at.5.38.47.PM.mov

✈️ 0.5.10

@imtuyethan
Copy link
Contributor Author

imtuyethan commented Nov 21, 2024

Nightly app is missing app updates progress at the bottom left:

Screen.Recording.2024-11-21.at.5.56.05.PM.mov

✈️ 0.5.10

@imtuyethan
Copy link
Contributor Author

imtuyethan commented Nov 21, 2024

Import model from HF: https://huggingface.co/latestissue/rwkv-6-world-1b6-gguf
It does not show model size:

Some can run, some took super long to start the model.

Screenshot 2024-11-21 at 7 31 18 PM

Screenshot 2024-11-21 at 7 56 49 PM

✈️ 0.5.10

@imtuyethan
Copy link
Contributor Author

imtuyethan commented Nov 21, 2024

Screenshot 2024-11-21 at 7 33 15 PM Screenshot 2024-11-21 at 7 33 01 PM

✈️ 0.5.10

@imtuyethan
Copy link
Contributor Author

Encountered this issue why updating new version on Windows 10:

Screenshot 2024-11-21 at 10 47 37 PM

@imtuyethan
Copy link
Contributor Author

If users have no GPU, should not show Vulkan option, otherwise it introduces this:

Screenshot 2024-11-21 at 10 56 56 PM

✈️ 0.5.10

@imtuyethan
Copy link
Contributor Author

Before we release, need to fix 2 important issues:

  1. Can't adjust parameters in API server.
  2. bug: Factory reset operation timeout #4001

The rest of the issues go to v0.5.10.

@imtuyethan
Copy link
Contributor Author

imtuyethan commented Nov 21, 2024

Screenshot 2024-11-21 at 11 21 37 PM Screenshot 2024-11-21 at 11 22 54 PM

✈️ 0.5.10

@github-project-automation github-project-automation bot moved this from In Progress to Review + QA in Jan & Cortex Nov 22, 2024
@imtuyethan imtuyethan moved this from Review + QA to Completed in Jan & Cortex Nov 22, 2024
@urmauur urmauur mentioned this issue Nov 22, 2024
3 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
QA For tracking QA processes and initiatives
Projects
Archived in project
Development

No branches or pull requests

3 participants