Skip to content

Comparison of ai code assistance like Continue, Github Copilot & Windsurf

License

Notifications You must be signed in to change notification settings

sekR4/Code-Assistant-Tests

Repository files navigation

Code Assistant Tests

The Task

Build small web app that accepts an image as input through an UI and returns a description of the image. We'll tackle this task with:

  • Continue using self-hosted local models,
  • Github Copilot and
  • Windsurf.

We'll use Brief Product Requirements (click to see) as custom instructions for the code assistant within .continuerules, .github/copilot-instructions.md and .windsurfrules.

Brief Product Requirements

Project overview

A small locally running nice looking web app that accepts an image as input through an UI and returns a description of the image. Technologies Used:

  • Next.js 15+ as framework
  • TypeScript for type safety
  • Tailwind CSS for styling
  • FastAPI as backend (calling ollama model)

Core Functionalities

File Upload

  • Single file upload interface with drag-and-drop support
  • Immediate file processing upon selection
  • File type validation (png, jpg, jpeg)
  • File size validation (max 5MB)
  • Loading state indication during upload and processing
  • Error handling with user-friendly notifications

Image to Text

  • Automatically image gets described
  • Server-side (so here my local host) processing with temporary file storage
  • Comprehensive error handling

Result Display

  • Clean representation of image description
  • Formatted text display with proper whitespace handling
  • Option to copy text to clipboard with a click
  • Error state handling with user feedback

Docs

An example of image to text with ollama.

import ollama

response = ollama.chat(
    model='llama3.2-vision',
    messages=[{
        'role': 'user',
        'content': 'What is in this image?',
        'images': ['image.jpg']
    }]
)

print(response)

Basic folder structure

root/
  backend/
    main.py
    pyproject.toml
    ...
  frontend/
    package.json
    ...

Implementation notes

  • Use Llama 3.2 Vison https://ollama.com/library/llama3.2-vision (ollama pull llama3.2-vision)
  • Install Node brew install node & run npx create-next-app@latest. Name the app frontend
  • Within backend/ run uv init && uv add fastapi (don't use pip)

Prompts I used

Example prompt (so that you can read the conversation history better):

Write a haiku

I do the setup myself to not distract the model and to set some structure. Note: for each ai tool reference to files/folders via '@' or '#'. Don't just copy the prompt. Should help the model understand the context better.

So for a replay, clone the repo and cd into the img-to-text-with-<INSERT_TOOL_NAME> folder and open VSC (Continue & Copilot) or Windsurf.

1. File Upload

Preparation

cd img-to-text-with-<INSERT_TOOL_NAME>
npx create-next-app@latest frontend

Initial prompt:

I created the nextjs project within img-to-text-with-<INSERT_TOOL_NAME>/frontend. Help me implementing the File Upload feature. Note, we'll work on img-to-text-with-<INSERT_TOOL_NAME>/backend after that.

Follow up commands & prompts Nothing to do with **Windsurf** ✅.

Continue works differently. Have to use the Chat and first create files by myself.

mkdir -p frontend/app/components
touch frontend/app/components/FileUploader.tsx
code frontend/app/components/FileUploader.tsx

Then I pushed 'Apply' for the first code snippet. The FileUploader had additional dependencies which the model mentioned further below in the chat. Had to

cd frontend && npm install react-toastify

The model also wrote I should create a page pages/index.tsx. But within frontend/app there was already a default page.tsx. I just opened it and pushed 'Apply'. Fixed the import path for FileUploader and removed an underlined word newWindow. Nothing red.

Check if it worked

npm run dev
open http://localhost:3000

Encountered this error with Continue and copy&pasted it into the chat.

⨯ ./app/components/FileUploader.tsx:1:17
Ecmascript file had an error
> 1 | import React, { useState } from 'react';
    |                 ^^^^^^^^
  2 | import { toast } from 'react-toastify';
  3 |
  4 | const FileUploader = () => {

You're importing a component that needs `useState`. This React hook only works in a client component. To fix, mark the file (or its parent) with the `"use client"` directive.

The model suggested to add "use client" on top of FileUploader.tsx. That was the fix. Frontend worked as expected.

2. Image to Text

Preparation

ollama pull llama3.2-vision # if you don't already have it
cp test_image.png img-to-text-with-<INSERT_TOOL_NAME>/backend
cd img-to-text-with-<INSERT_TOOL_NAME>/backend && uv init && uv add fastapi

Initial prompt:

We've created a nice looking UI. Now let's move on to Image to Text. I initialized the uv project first and installed FastAPI for the backend (cd backend && uv init && uv add fastapi). Create the fastapi backend. It should accept an image as input from the frontend, send the image to the ollama model (you have an example for this) and receive the response from ollama. I also provided a test_image.png in backend/.

Follow up commands & prompts: Windsurf did all. Had nothing to do.✅

Continue wanted me to work.

cd backend && mv hello.py main.py
code main.py

Then I 'Apply'. Discovered ModuleNotFoundError: No module named 'ollama'. Fixed it quickly uv add ollama.

Check if it worked

uv run uvicorn main:app --reload
curl -X POST http://localhost:8000/<PATH_MAY_VARY> -F file=@test_image.png

The backend I created with Continue responded with {"detail":"'description'"} after I send this curl -X POST http://localhost:8000/describe-image/ -F file=@test_image.png. Changed return {"description": response["description"]} to return {"description": response['message']['content']}

Then it worked.

3. Result Display

Frontend seems to work and the backend as well (both are turned off at the moment). Now let's work on Result Display.

Follow up commands & prompt Continue:

Can't u handle the changes u suggested within @page.tsx, @FileUploader.tsx and @main.py?

It basically showed me content of the files I mentioned. Only FileUploader.tsx contained changes I 'Apply'd. Had to npm install axios ... Why?

Can't click on the Upload button.

Then several iterations more. Gave up. ❌

Follow up commands & prompt Windsurf:

It should all work at http://localhost:3000. Also note that npm server and fastapi have to be running so that i can try

Check if it worked

uv run uvicorn main:app --reload
npm run dev

Follow up prompt:

In general it works. But it would also be nice to see the image which was uploaded. Let's add that.

Results & Conclusion

Working with Windsurf ✅:

  • Holy!
  • Fast iterations. Fixed issues automagically.
  • Created a nice looking web app that did what I wanted.

Working with Continue ❌:

  • Macbook got loud sometimes. Had to brew services restart ollama or stop ollama completely (100% GPU).
  • In the chat ENTER was my friend. CMD+ENTER confused the model since it checked the whole codebase.
  • The backend was created without any issues. Frontend didn't work as expected. Couldn't upload a file. Not sure what the issue was. Don't have much experience with it. Gave up.

Working with Copilot (COMING SOON):

  • ...

About

Comparison of ai code assistance like Continue, Github Copilot & Windsurf

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published