BitDex Filter Testing
Test that BitDex correctly handles all image search filter combinations used across the site.
Best use case
BitDex Filter Testing is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Test that BitDex correctly handles all image search filter combinations used across the site.
Teams using BitDex Filter Testing should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/bitdex-test/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How BitDex Filter Testing Compares
| Feature / Agent | BitDex Filter Testing | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Test that BitDex correctly handles all image search filter combinations used across the site.
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
Related Guides
AI Agents for Coding
Browse AI agent skills for coding, debugging, testing, refactoring, code review, and developer workflows across Claude, Cursor, and Codex.
AI Agents for Marketing
Discover AI agents for marketing workflows, from SEO and content production to campaign research, outreach, and analytics.
AI Agents for Startups
Explore AI agent skills for startup validation, product research, growth experiments, documentation, and fast execution with small teams.
SKILL.md Source
# BitDex Filter Testing
Test that BitDex correctly handles all image search filter combinations used across the site.
## Prerequisites
A dev server (or production) must be running with BitDex enabled (Flipt `bitdex-image-search` set to `primary` or `shadow`).
## Scripts
### 1. `query.mjs` — Interactive Query Tool
Run individual queries against the image search endpoint. Use this to explore, debug, or verify specific filter combinations.
```bash
# Basic query
node .claude/skills/bitdex-test/query.mjs --sort Newest --limit 5
# Filter by type and base model
node .claude/skills/bitdex-test/query.mjs --sort "Most Reactions" --types image --base-models "SD 1.5"
# User profile view
node .claude/skills/bitdex-test/query.mjs --username civitai --sort Newest
# Model gallery view
node .claude/skills/bitdex-test/query.mjs --model-version-id 12345 --sort "Most Reactions"
# Remixes
node .claude/skills/bitdex-test/query.mjs --remix-of 12345
node .claude/skills/bitdex-test/query.mjs --remixes-only
node .claude/skills/bitdex-test/query.mjs --non-remixes-only
# NSFW filtering (bitmask: PG=1, PG13=2, R=4, X=8, XXX=16)
node .claude/skills/bitdex-test/query.mjs --nsfw 1 # PG only
node .claude/skills/bitdex-test/query.mjs --nsfw 3 # PG+PG13
node .claude/skills/bitdex-test/query.mjs --nsfw 31 # All (default)
# Machine-readable output
node .claude/skills/bitdex-test/query.mjs --json # Compressed JSON
node .claude/skills/bitdex-test/query.mjs --raw # Full tRPC response
# Pagination
node .claude/skills/bitdex-test/query.mjs --cursor "200|bdx:{...}"
```
**All flags**: `--base-url`, `--limit`, `--sort`, `--period`, `--types`, `--tags`, `--tools`, `--techniques`, `--base-models`, `--user-id`, `--username`, `--model-id`, `--model-version-id`, `--post-id`, `--remix-of`, `--remixes-only`, `--non-remixes-only`, `--with-meta`, `--from-platform`, `--nsfw`, `--cursor`, `--raw`, `--json`
### 2. `test-filters.mjs` — Full Test Suite
Runs all filter combinations organized by site context and outputs a markdown report.
```bash
# Run all tests
node .claude/skills/bitdex-test/test-filters.mjs
# Run specific section
node .claude/skills/bitdex-test/test-filters.mjs --section main-feed
# List available sections
node .claude/skills/bitdex-test/test-filters.mjs --list
# Save report to file
node .claude/skills/bitdex-test/test-filters.mjs --output docs/working/bitdex-test-results.md
# Verbose (includes query params in output)
node .claude/skills/bitdex-test/test-filters.mjs --verbose
```
**Test sections**:
| Section | What it covers |
|---------|---------------|
| `main-feed` | /images page — all sorts, periods, types, base models, meta, platform, remix filters, NSFW levels, combinations |
| `user-profile` | User profile image tab — user-scoped queries with sorts and type filters |
| `model-gallery` | Model version gallery — modelVersionId-scoped queries |
| `post-detail` | Post detail page — postId-scoped queries |
| `remix-detail` | Image remix tab — remixOfId queries |
| `edge-cases` | Empty results, limit boundaries, multi-tag filters |
## How to Review Results
When reviewing the markdown output, look for:
1. **Errors (❌)**: Any query that returned an HTTP error — likely a filter that BitDex doesn't handle
2. **Empty results that shouldn't be**: Compare against what you'd expect (e.g., "Newest images" should never be empty)
3. **Wrong sort order**: Check that "Most Reactions" results are sorted by reaction count descending, "Newest" by date descending, etc.
4. **NSFW leakage**: PG-only queries should not return images with nsfwLevel > 1
5. **Type mismatches**: "image only" queries should not return videos
6. **Missing data**: Check that stats, tags, user info, and metadata are populated
7. **Date sanity**: Dates should be reasonable (not year 2106 or 1970)
## Extending Tests
Add new test cases to the `sections` object in `test-filters.mjs`. Each test is a `[name, inputObject]` tuple where `inputObject` matches the `getInfiniteImagesSchema` fields.
For model-specific or post-specific tests, the agent should first discover real IDs using `query.mjs` and then substitute them into the test cases.Related Skills
worktree
Create and manage git worktrees with automatic environment setup. Creates worktrees at ../model-share-<branch>, copies .env, and runs pnpm install.
ux-design
UX design methodology and external consultation. Use when creating user flows, wireframes, interaction patterns, or getting UX feedback. Provides structured frameworks for user-centered design.
retool-query
Run queries against the Retool PostgreSQL database for moderation notes, user notes, and other Retool-managed data. Read-only by default. Use when you need to query the Retool database directly.
redis-inspect
Inspect Redis cache keys, values, and TTLs for debugging. Supports both main cache and system cache. Use for debugging cache issues, checking cached values, and monitoring cache state. Read-only by default.
ralph
Autonomous agent for tackling big projects. Create PRDs with user stories, then run them via the CLI. Sessions persist across restarts with pause/resume and real-time monitoring.
quick-mockups
Create multiple UI design mockups in parallel. Use when asked to create mockups, wireframes, or design variations for a feature. Creates HTML files using Mantine v7 + Tailwind following Civitai's design system.
postgres-query
Run PostgreSQL queries for testing, debugging, and performance analysis. Use when you need to query the database directly, run EXPLAIN ANALYZE, compare query results, or test SQL optimizations. Always uses read-only connections unless explicitly directed otherwise.
opensearch-admin
Inspect and debug OpenSearch clusters — health, index stats, search performance, query profiling, mappings, shards, and thread pools. Read-only admin operations for monitoring and troubleshooting.
mod-actions
Take moderator actions on users - ban, mute, remove content, manage leaderboard eligibility, send DMs. Use when you need to ban a user, mute them, send direct messages, or take other moderation actions.
metabase
Create and manage Metabase questions, dashboards, and public links. Use when the user wants to build metrics dashboards, create saved questions with SQL queries, or share analytics publicly.
meilisearch-admin
Check Meilisearch index status, tasks, health, and settings. Use for debugging search issues, monitoring indexing tasks, and inspecting index configuration. Read-only admin operations.
freshdesk
Interact with Freshdesk support platform - search/view/update tickets, reply to customers, add notes, look up contacts, and manage Knowledge Base articles. Use when you need to manage support tickets, look up customer information, or work with KB content.