npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@kernel-labs/glimpse

v0.1.1

Published

Upload Playwright screenshots to Supabase/S3 and post to GitHub PR comments

Downloads

9

Readme

Glimpse

Upload Playwright screenshots to Supabase or S3 and automatically post them to GitHub PR comments for easy visual review.

Features

  • 📸 Automated Screenshot Upload - Upload Playwright test screenshots to Supabase or S3
  • 🧪 Test Helpers - Capture screenshots directly in your Playwright tests
  • 💬 GitHub PR Comments - Automatically post screenshots as PR comments
  • 🔄 Update Existing Comments - Updates the same comment instead of creating duplicates
  • ☁️ Multiple Storage Options - Support for Supabase Storage and AWS S3
  • 🛠️ Flexible - CLI tool for CI environments or programmatic API for custom workflows
  • 🎯 Framework Focused - Designed specifically for Playwright + GitHub Actions

Installation

npm install --save-dev @kernel-labs/glimpse

Quick Start

Capturing Screenshots in Tests

Use the provided helper functions to capture screenshots directly in your Playwright tests. This approach works with your existing test setup and custom fixtures.

captureScreenshot

The simplest way to capture screenshots. Use this when you want basic screenshot functionality without Playwright test report integration:

import { test, expect } from '@playwright/test'
import { captureScreenshot } from '@kernel-labs/glimpse/playwright'

test('my app', async ({ page }) => {
  await page.goto('https://example.com')

  // Capture screenshot using helper
  await captureScreenshot(page, 'homepage')

  // Continue testing
  await page.click('button#login')
  await captureScreenshot(page, 'login-dialog')

  // With options
  await captureScreenshot(page, {
    name: 'dashboard',
    fullPage: true,
    screenshotOptions: {
      animations: 'disabled'
    }
  })
})

Characteristics:

  • Saved to: test-results/pr-screenshots/ (configurable via PR_SCREENSHOTS_DIR env var)
  • Filename is exactly as provided (i.e. homepage.png)
  • Does NOT attach to Playwright test report

captureScreenshotWithInfo

Use this when you want better integration with Playwright's test runner and reporting:

import { test, expect } from '@playwright/test'
import { captureScreenshotWithInfo } from '@kernel-labs/glimpse/playwright'

test('my app', async ({ page }, testInfo) => {
  await page.goto('https://example.com')

  // Capture screenshot with test context
  await captureScreenshotWithInfo(page, testInfo, 'homepage')

  // Continue testing
  await page.click('button#login')
  await captureScreenshotWithInfo(page, testInfo, 'login-dialog')

  // With options
  await captureScreenshotWithInfo(page, testInfo, {
    name: 'dashboard',
    fullPage: true,
    screenshotOptions: {
      animations: 'disabled'
    }
  })
})

Characteristics:

  • Saved to: test-results/pr-screenshots/ (configurable via PR_SCREENSHOTS_DIR env var)
  • Filename: my-app-homepage.png (prefixed with test name to avoid conflicts)
  • Attaches screenshot to Playwright test report (visible in HTML reports)
  • Better for test organization and debugging

When to use which:

  • Use captureScreenshotWithInfo if you want screenshots in Playwright's HTML reports or need test name prefixes
  • Use captureScreenshot if you prefer simpler filenames and don't need test report integration

Screenshots are automatically saved to test-results/pr-screenshots/ (configurable via PR_SCREENSHOTS_DIR env var).

CLI Usage (For Uploading)

With Supabase Storage

# Upload screenshots
npx glimpse upload \
  --directory ./test-results \
  --storage supabase \
  --pr 123

# Environment variables required:
# SUPABASE_URL=https://your-project.supabase.co
# SUPABASE_PRIVATE_KEY=your-service-key

With S3 Storage

# Upload screenshots
npx glimpse upload \
  --directory ./test-results \
  --storage s3 \
  --pr 123

# Environment variables required:
# AWS_REGION=us-east-1
# S3_BUCKET=my-screenshots
# AWS_ACCESS_KEY_ID=your-access-key (optional, uses default AWS credentials)
# AWS_SECRET_ACCESS_KEY=your-secret-key (optional)

GitHub Actions Integration

Run this after your tests are completed:

name: UI Screenshots

on:
  pull_request:
    branches: [main]

jobs:
  screenshots:
    name: Generate UI Screenshots
    runs-on: ubuntu-latest

    permissions:
      contents: read
      pull-requests: write

    steps:
      - uses: actions/checkout@v4

      - uses: actions/setup-node@v4
        with:
          node-version: '20.x'

      - name: Install dependencies
        run: npm ci

      - name: Install Playwright
        run: npx playwright install --with-deps chromium

      - name: Build app
        run: npm run build

      - name: Run tests with screenshots
        run: npm run test:e2e
        # Your tests should use the screenshot helpers to capture screenshots

      # Upload to Supabase
      - name: Upload screenshots to Supabase
        if: always()
        env:
          SUPABASE_URL: ${{ secrets.SUPABASE_URL }}
          SUPABASE_PRIVATE_KEY: ${{ secrets.SUPABASE_PRIVATE_KEY }}
          PR_NUMBER: ${{ github.event.pull_request.number }}
          RUN_ID: ${{ github.run_id }}
        run: |
          npx glimpse upload \
            --directory ./test-results \
            --storage supabase

      # Post to PR
      - name: Post screenshots to PR
        if: always()
        uses: actions/github-script@v7
        with:
          script: |
            const fs = require('fs');
            const { postToGitHub } = await import('${{ github.workspace }}/node_modules/@kernel-labs/glimpse/dist/index.js');

            const screenshots = JSON.parse(fs.readFileSync('screenshot-urls.json', 'utf8'));

            await postToGitHub({
              screenshots,
              prNumber: context.issue.number,
              owner: context.repo.owner,
              repo: context.repo.repo,
              runId: context.runId,
              repositoryUrl: context.payload.repository.html_url,
              token: process.env.GITHUB_TOKEN
            }, github);

Using S3 Instead of Supabase

Just replace the upload step:

      - name: Upload screenshots to S3
        if: always()
        env:
          AWS_REGION: us-east-1
          S3_BUCKET: my-screenshots
          AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }}
          AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
          PR_NUMBER: ${{ github.event.pull_request.number }}
          RUN_ID: ${{ github.run_id }}
        run: |
          npx glimpse upload \
            --directory ./test-results \
            --storage s3

Storage Configuration

Supabase

ENV needed:

  • SUPABASE_URL: Your Supabase project URL
  • SUPABASE_PRIVATE_KEY: Your Supabase service role key
  • SUPABASE_BUCKET: Optional if you need a custom bucket name (default: screenshots)

AWS S3

  1. Create an S3 bucket
  2. Configure bucket permissions for public read (or use presigned URLs)
  3. Add secrets to your GitHub repository:
    • AWS_ACCESS_KEY_ID: Your AWS access key
    • AWS_SECRET_ACCESS_KEY: Your AWS secret key

Environment variables:

  • AWS_REGION or S3_REGION: AWS region (required)
  • S3_BUCKET or AWS_BUCKET: Bucket name (required)
  • S3_ENDPOINT: Custom endpoint for S3-compatible services (optional)
  • S3_PUBLIC_READ: Set to false to disable public read ACL (default: true)

S3-Compatible Services

The library works with any S3-compatible service (MinIO, DigitalOcean Spaces, Backblaze B2, etc.):

S3_ENDPOINT=https://nyc3.digitaloceanspaces.com \
S3_REGION=us-east-1 \
S3_BUCKET=my-screenshots \
npx glimpse upload --directory ./test-results --storage s3

CLI Reference

upload command

Upload screenshots to storage.

npx glimpse upload [options]

Options:

  • -d, --directory <path> - Directory containing screenshots (required)
  • -s, --storage <type> - Storage type: supabase or s3 (required)
  • -p, --pr <number> - PR number (optional, can use PR_NUMBER env var)
  • -r, --run-id <id> - CI run ID (optional, can use RUN_ID env var)
  • -t, --path-template <template> - Path template for uploaded files (default: pr-{pr}/run-{runId}/{filename})
  • -o, --output <path> - Output file for screenshot URLs (default: screenshot-urls.json)

generate-comment command

Generate PR comment markdown from uploaded screenshots.

npx glimpse generate-comment [options]

Options:

  • -i, --input <path> - Input file with screenshot URLs (required)
  • -p, --pr <number> - PR number
  • -r, --run-id <id> - CI run ID
  • --repo-url <url> - Repository URL
  • -o, --output <path> - Output file for comment markdown

API Reference

Other functions you can use if you want to customize your workflow:

uploadScreenshots(options)

Upload screenshots to the configured storage provider.

interface UploadOptions {
  directory: string
  storage: StorageConfig
  pathTemplate?: string
  prNumber?: string | number
  runId?: string | number
}

const screenshots = await uploadScreenshots(options)

postToGitHub(options, githubClient)

Post or update a GitHub PR comment with screenshots.

interface GitHubCommentOptions {
  screenshots: UploadedScreenshot[]
  prNumber: number
  token: string
  owner: string
  repo: string
  runId?: string | number
  repositoryUrl?: string
}

await postToGitHub(options, github)

generateCommentBody(options)

Generate markdown for a GitHub PR comment.

const markdown = generateCommentBody(options)

Development

# Install dependencies
npm install

# Build
npm run build

# Watch mode
npm run dev

License

MIT

Contributing

Please open an issue before proposing a PR if you'd like to contribute.