import { DATASETS, ModelCard, MODELS } from '$lib'
import { ALL_METRICS } from '$lib/labels'
import { format_num } from 'matterviz'
import { mount } from 'svelte'
import { describe, expect, it } from 'vitest'

describe(`ModelCard`, () => {
  // Get a real model from MODELS
  const model = MODELS.find((m) => m.model_key === `mace-mp-0`)
  if (!model) throw new Error(`Could not find mace-mp-0 model in MODELS`)

  const metrics = ([`F1`, `DAF`, `κ_SRME`] as const).map((key) => ({
    key,
    ...ALL_METRICS[key],
  }))

  describe(`Basic Rendering`, () => {
    it(`renders model header and basic info`, () => {
      mount(ModelCard, {
        target: document.body,
        props: { model, metrics, sort_by: `F1` },
      })

      const header = document.querySelector(`h2`)
      expect(header?.textContent).toContain(`MACE`)

      const links = document.querySelectorAll<HTMLAnchorElement>(`nav a`)
      expect(links.length).toBeGreaterThan(0)
      expect(links[0].href).toBe(model.repo)

      const info_spans = document.querySelectorAll(`section.metadata > span`)
      // Training set is now first in the metadata section, so we need to check other spans
      // Find the date_added span by its content
      const date_added_span = Array.from(info_spans).find((span) =>
        span.textContent?.includes(`Added ${model.date_added}`)
      )
      expect(date_added_span).toBeDefined()
      expect(date_added_span?.textContent).toContain(model.date_added)

      if (model.date_published) {
        const date_published_span = Array.from(info_spans).find((span) =>
          span.textContent?.includes(`Published ${model.date_published}`)
        )
        expect(date_published_span).toBeDefined()
        expect(date_published_span?.textContent).toContain(model.date_published)
      }

      const params_span = Array.from(info_spans).find((span) =>
        span.textContent?.includes(`${format_num(model.model_params, `.3~s`)} params`)
      )
      expect(params_span).toBeDefined()
    })

    it(`handles missing optional fields gracefully`, () => {
      const minimal_model = {
        ...model,
        date_published: undefined,
        paper: undefined,
        url: undefined,
      }

      mount(ModelCard, {
        target: document.body,
        props: { model: minimal_model, metrics, sort_by: `F1` },
      })

      const links = document.querySelectorAll(`nav a`)
      expect(links.length).toBeGreaterThan(0)
      expect(document.body.textContent).not.toContain(`Published`)
    })
  })

  // Rest of the tests remain similar but use real_model instead of real_model
  // and adjust expectations based on actual model data...

  it(`handles training set display`, () => {
    mount(ModelCard, {
      target: document.body,
      props: { model, metrics, sort_by: `F1` },
    })

    // Look for span containing "Training set" text
    const training_set = Array.from(
      document.querySelectorAll(`section.metadata span`),
    ).find((span) => span.textContent?.includes(`Training data`))
    expect(training_set).toBeDefined()
    expect(training_set?.textContent).toContain(`Training data:`)

    // Test actual training set data
    const training_set_links = training_set?.querySelectorAll(`a`)
    if (training_set_links) {
      const dataset_key = model.training_set[0]
      const dataset = DATASETS[dataset_key]

      // Check that we're linking to our internal data page
      expect(training_set_links[0].href).toContain(`/data/${dataset.slug}`)

      // Check that structure count is shown in tooltip
      const formatted_structures = format_num(dataset.n_structures)
      expect(training_set_links[0].title).toContain(`${formatted_structures} structures`)
    }
  })

  describe(`Metrics Display`, () => {
    it(`displays metrics with correct formatting`, () => {
      mount(ModelCard, {
        target: document.body,
        props: { model, metrics, sort_by: `F1` },
      })

      const metrics_lis = document.querySelectorAll(`.metrics li`)
      expect(metrics_lis.length).toBeGreaterThan(0)

      const f1_metric = Array.from(metrics_lis).find((m) => m.textContent?.includes(`F1`))
      const f1_value = model.metrics?.discovery?.unique_prototypes?.F1
      expect(f1_metric?.querySelector(`strong`)?.textContent?.trim()).toBe(
        f1_value?.toString(),
      )
      expect(f1_metric?.classList.contains(`active`)).toBe(true)

      const kappa_metric = Array.from(metrics_lis).find((m) =>
        m.textContent?.includes(`κ`)
      )
      const kappa_value = model.metrics?.phonons?.kappa_103?.κ_SRME
      expect(kappa_metric?.querySelector(`strong`)?.textContent?.trim()).toBe(
        `${kappa_value}`,
      )
    })

    it(`handles missing metrics`, () => {
      const model_without_metrics = { ...model, metrics: undefined }

      mount(ModelCard, {
        target: document.body,
        props: { model: model_without_metrics, metrics, sort_by: `F1` },
      })

      const metrics_li_strong = document.querySelectorAll(`.metrics li strong`)[0]
      expect(metrics_li_strong.textContent?.trim()).toBe(`n/a`)
    })
  })

  describe(`Expandable Details`, () => {
    it(`toggles details section visibility`, () => {
      let show_details = $state(false)
      mount(ModelCard, {
        target: document.body,
        props: { model, metrics, sort_by: `F1`, show_details },
      })

      // Initially only metrics section should be visible
      const initial_sections = document.querySelectorAll(`section:not(.metrics) h3`)
      expect(initial_sections).toHaveLength(0)

      show_details = true
      const sections = document.querySelectorAll(`section h3`)
      const section_titles = Array.from(sections).map((h3) => h3.textContent)
      expect(section_titles).toEqual([`Metrics`])
    })

    it(`displays authors and package versions correctly`, () => {
      mount(ModelCard, {
        target: document.body,
        props: { model, metrics, sort_by: `F1`, show_details: true },
      })

      // Check author info within the list item
      const author_li = document.querySelector(`section:first-child ul li`)
      expect(author_li?.textContent?.trim()).toContain(model.authors[0].name)

      // Check package versions
      const packages = Array.from(
        document.querySelectorAll(`section:nth-child(2) li`),
      )
      expect(packages.length > 0).toBe(true)
      const first_package = Object.entries(model.requirements ?? {})[0]
      if (first_package) {
        const [pkg_name, pkg_version] = first_package
        expect(packages[0].textContent?.trim()).toBe(`${pkg_name}: ${pkg_version}`)
      }
    })
  })

  describe(`regression tests for default values`, () => {
    it(`verifies show_details defaults to false to catch regressions`, () => {
      mount(ModelCard, {
        target: document.body,
        props: { model, metrics, sort_by: `F1` },
      })

      // Test show_details default (should be false - no detail sections visible)
      const detail_sections = document.querySelectorAll(
        `section:not(.metrics):not(.metadata) h3`,
      )
      expect(detail_sections.length, `show_details should default to false`).toBe(0)
    })
  })
})
