{"slug": "80-impressions-every-visible-one-is-for-a-company-i-invented-in-a-typescript", "title": "80 Impressions. Every Visible One Is for a Company I Invented in a TypeScript File.", "summary": "A developer discovered that 80 impressions on their blog came from searches for a fictional company, TechFlow Solutions, which was invented in a TypeScript file and used as an example in AI-generated content. The automated blog generation system on valuefy.app uses a Supabase edge function and Gemini to produce posts, and Google indexed the fake company name alongside M&A terms, leading to irrelevant traffic. The developer notes that the impressions are from automated research tools rather than genuine readers, and similar patterns of invisible long-tail queries have appeared across multiple content clusters.", "body_md": "80 impressions. Our best-performing blog page in the last 28 days — by far. I pulled the query breakdown expecting to see what people were actually searching for when they found it.\n\nEvery visible query contained the name of a company that does not exist.\n\nBlog generation on valuefy.app is automated. A scheduled routine picks a topic, hits a Supabase edge function, and the edge function calls Gemini with a large system prompt assembled from `prompt-builder.ts`\n\n. That prompt contains, among other things, a block of fictional case study companies — examples injected so the AI produces naturalistic-sounding content instead of abstract theory.\n\nOne of those companies is TechFlow Solutions: an IT consulting firm in Stockholm, revenue SEK 22M, shifted from services to SaaS, hybrid model confused buyers, eventually split the business and sold the services side at 4x.\n\nTechFlow Solutions does not exist. It was written into the prompt template so the AI would write concrete stories instead of generic advice.\n\nThe blog post \"The valuation reset: navigating lower exit multiples in today's M&A market\" was generated using that prompt. The AI apparently used TechFlow Solutions as an example. Google read the post, indexed the company name alongside the M&A due diligence language surrounding it, and decided: this is the right page to show when someone searches for TechFlow Solutions' financial data.\n\nThe valuation reset post sits at average position 7.1 with 80 impressions over 28 days. That's the most visible blog page in GSC right now. I expected the query breakdown to show something like \"exit multiples 2024\" or \"lower valuation M&A\" — the actual topic of the post.\n\nHere's what came back:\n\n| Query | Impressions | Position |\n|---|---|---|\n| \"techflow solutions\" \"normalized ltm ebitda\" or \"qoe\" or \"quality of earnings\" | 6 | 7.0 |\n| \"techflow solutions\" \"qoe\" or \"quality of earnings\" or \"normalized ltm ebitda\" | 5 | 7.0 |\n\nTwo rows. Eleven impressions total. Out of 80.\n\nThe other 69 impressions don't appear in the query breakdown — they're below GSC's privacy threshold, one or two impressions each, invisible. But based on the two that surface, the pattern is clear: someone is searching for \"TechFlow Solutions\" alongside specific M&A due diligence terms. That's not a person looking to understand exit multiples. That's due diligence research on a specific company — combined with the kind of financial language a quality-of-earnings analyst would use.\n\nA company that was invented inside a TypeScript file.\n\nThe chain, traced through the code:\n\n`supabase/functions/_shared/prompt-builder.ts`\n\ncontains a fictional case studies blockThe impressions are not from people interested in exit multiples. They're from people — or more likely automated research tools — that encountered \"TechFlow Solutions\" somewhere and went looking for more. Position 7 for a fictional company is not a success. It's 80 impressions from completely the wrong audience, plus zero clicks because the page can't give those searchers what they actually want.\n\nThis week the automation improved seven more calculator pages: Valuation Multiple (June 21), CPC (June 22), CTR (June 23), ROAS (June 24), CPA (June 25), Ad Spend (June 26), Burn Rate (June 27). Five of the seven are marketing calculators — the advertising cluster.\n\nThe CTR calculator is the only one with any GSC presence in the 28-day window. The page data shows 19 impressions, position 5.5, one click, and a 5.26% CTR. Position 5.5 on a competitive marketing term. That looks promising.\n\nThen the query drill came back with zero rows.\n\nNot low positions — no visible queries at all. All 19 impressions are below GSC's threshold: dozens of micro-impressions from long-tail variants, none large enough to appear. The average position 5.5 is arithmetic across an invisible distribution, the same pattern that's appeared for five consecutive clusters now. The other five advertising calculators don't appear in the top 50 pages even in the full 28-day window.\n\nOne note on the CTR calculator specifically: it does have a decent title from the automation — \"CTR Calculator: Click-Through Rate & Benchmarks | Valuefy\" — and a meta description that mentions specific platform benchmarks. The content improvement is real. The traffic just isn't there yet, and may not be given the competition for those terms.\n\nThe daily automation has run without interruption since May 16: 42 consecutive commits, one per day, one calculator page per commit. The commit on June 27 was the Burn Rate calculator — same page as the very first commit on May 16. The queue has cycled back to the beginning.\n\nThat means we now have one complete pass through 42 pages, and the second pass has started. Whether improving a page for a second time — now that it's been indexed and potentially settled into a position — produces different results from the first pass is the question I don't have data to answer yet. I'll check back once the second pass is a few weeks in.\n\n`prompt-builder.ts`\n\nbefore the next content generation run.The fictional company names were put into the prompt to make the output sound better. Not to deceive anyone — there's no intent to mislead — but because \"a company called TechFlow Solutions solved this exact problem\" reads more naturally than \"imagine a company that solved this exact problem.\" Concrete examples. Specific details. The usual advice for good writing.\n\nThe problem is that \"better-sounding content\" and \"well-indexed content\" pull in different directions when the named examples are invented. Content that sounds naturalistic to a human reader creates exact-match fingerprints in the search index. Google doesn't know TechFlow Solutions was typed into a prompt last year and that no actual business by that name exists. It sees a document containing \"TechFlow Solutions\" and \"normalized LTM EBITDA\" together and decides: when someone searches for both, show this page.\n\nNamed fictional entities in AI prompts are an SEO liability, not just a content-quality concern. Every invented company name, product name, or made-up case study is a potential keyword anchor that might attract queries for the wrong audience. For a valuation blog post trying to rank for \"exit multiple trends,\" phantom impressions from TechFlow Solutions research queries are noise at best and a ranking dilution signal at worst.\n\nThe fix is narrow: strip the names, keep the numbers. The lesson is broader: when you're writing prompts for content that will be indexed, every named entity is a keyword decision — including the ones you invented.\n\nI'll pull the query data again in four weeks. If the renamed prompt clears out the phantom impressions, that's a data point worth publishing. If the page is already permanently associated with TechFlow Solutions in Google's index and the queries persist, I'll say that too.\n\nI'm running these experiments on [valuefy.app](https://valuefy.app) and writing up what actually happens, including the parts that go sideways. If you're building with AI-generated content, debugging unexpected impressions, or working through the same \"content looks right but rankings don't follow\" problem, I'd love to compare notes — drop a comment or reach out.\n\nI also run [AImiten](https://aimiten.fi), where we build AI tooling for companies. This side project is where I stress-test ideas before they touch client work.", "url": "https://wpnews.pro/news/80-impressions-every-visible-one-is-for-a-company-i-invented-in-a-typescript", "canonical_source": "https://dev.to/aimiten/80-impressions-every-visible-one-is-for-a-company-i-invented-in-a-typescript-file-3bl", "published_at": "2026-06-28 07:10:34+00:00", "updated_at": "2026-06-28 07:33:37.057754+00:00", "lang": "en", "topics": ["generative-ai", "large-language-models", "ai-tools", "developer-tools"], "entities": ["TechFlow Solutions", "valuefy.app", "Supabase", "Gemini", "Google Search Console"], "alternates": {"html": "https://wpnews.pro/news/80-impressions-every-visible-one-is-for-a-company-i-invented-in-a-typescript", "markdown": "https://wpnews.pro/news/80-impressions-every-visible-one-is-for-a-company-i-invented-in-a-typescript.md", "text": "https://wpnews.pro/news/80-impressions-every-visible-one-is-for-a-company-i-invented-in-a-typescript.txt", "jsonld": "https://wpnews.pro/news/80-impressions-every-visible-one-is-for-a-company-i-invented-in-a-typescript.jsonld"}}