stevepike 16 hours ago

This is cool, it looks to me like you're integrating static analysis on the user's codebase and the underlying dependency. Very curious to see where it goes.

We've found dependency upgrades to be deceptively complex to evaluate safety for. Often you need context that's difficult or impossible to determine statically in a dynamically typed language. An example I use for Ruby is the kwarg migration from ruby 2.7->3 (https://www.ruby-lang.org/en/news/2019/12/12/separation-of-p...). It's trivial to profile for impacted sites at runtime but basically impossible to do it statically without adopting something like sorbet. Do you have any benchmarks on how reliable your evaluations are on plain JS vs. typescript codebases?

We ended up embracing runtime profiling for deprecation warnings / breaking changes as part of upgrading dependencies for our customers and have found that context to unlock more reliable code transformations. But you're stuck building an SDK for every language you want to support, and it's more friction than installing a github app.

rohitpaulk 17 hours ago

Always felt dependency updates are a perfect fit for AI agents:

(a) they’re broadly similar across companies,

(b) they aren’t time-sensitive, so the agent can take hours without anyone noticing, and

(c) customers are already accustomed to using bots here, just bad ones

  • XiZhao 17 hours ago

    One would imagine they are broadly similar; but that's off the assumption that codebases are similar as well.

    Migrations between versions can have big variance largely as a function of the parent codebase and not the dependency change. A simple example of this would be a supported node version bump. It's common to lose support for older node runtimes with new dependency versions, but migrating the parent codebase may require large custom efforts like changing module systems.

johnnyyw 17 hours ago

Why didn't GitHub come up with this? This seems like such an obvious use case.

  • timrogers 15 hours ago

    GitHub PM here. We have tried this, but we weren't able to get results that we were satisfied with. Of course, you have to revisit these things regularly, as the models and wider state of the art are evolving so quickly!

  • robszumski 17 hours ago

    It requires you to go deep in both the code analysis and the research, which is expensive at their scale

    And, as someone who's start up (EdgeBit was acquired by FOSSA recently) wrote a new JS/TS static analysis engine, it's just hard to get correct.

  • chadfurman 17 hours ago

    It's a niche for AI, which creates some great opportunities for context engineering :)

  • zingababba 16 hours ago

    GitHub hasn't done anything interesting with dependabot or code scanning for awhile.

    • danudey 14 hours ago

      They're spending all of their engineering resources on not doing anything interesting with Copilot instead.

      • viraptor 7 hours ago

        And not solving lots of small issues listed on... GitHub. The community project is such an issues graveyard.

  • SkyPuncher 10 hours ago

    Because this won't work. Dependency updates are actually incredibly hard.

cchance 10 hours ago

This seems great, i see you offer it as a service, but also its opensource (FOSS) ... how does the FOSS version differ from the commercial service?

  • jamietanna 4 hours ago

    > also its opensource (FOSS)

    Where did you see that? I must've missed it in the announcement

gregjw 10 hours ago

Did they not Google the name before deciding upon it? Fossabot is a dominant player in online streaming chat moderation.

jamietanna 16 hours ago

This is very interesting, looking forward to seeing more about it!

(I'm one of the maintainers on Renovate)

ai-christianson 13 hours ago

Cool to see this coming out of FOSSA (ex FOSSA here :))