Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Upgrading from 2.16.1 to 2.17.0 breaks our app #903

Closed
adamivancza opened this issue Dec 6, 2023 · 13 comments
Closed

Upgrading from 2.16.1 to 2.17.0 breaks our app #903

adamivancza opened this issue Dec 6, 2023 · 13 comments
Labels
bug Something isn't working 🚧 Work In Progress

Comments

@adamivancza
Copy link

  • analytics-react-native version: 2.17.0
  • Integrations versions (if used): @segment/analytics-react-native-plugin-firebase / 0.3.11, @segment/sovran-react-native / 1.0.4
  • React Native version: 0.72.5
  • iOS or Android or both? both

Steps to reproduce

I've tried to update our from 2.16.1 to 2.17.0 the app won't start up and I can see this message on the packager console:

TypeError: Super expression must either be null or a function, js engine: hermes

We have a couple of custom plugins as well, tried to disable all of them but nothing seemed to help.

Expected behavior

App should be able to start up with the most recent version

Actual behavior

Unhandled error in the packager output, app stuck on splash screen

@adamivancza adamivancza added the bug Something isn't working label Dec 6, 2023
@oscb
Copy link
Contributor

oscb commented Dec 6, 2023

Hey @adamivancza, we deprecated 2.17 for now until we get down to this error. Seems to have started happening in later versions of RN.

Quick question: could you share a minimal repro project? I don't think the problem is likely your app code, but I feel it's likely something about babel, typescript or RN configuration itself. Possible some interaction between versions of those tools and our code.

We've been trying to repro this with simple apps with no luck, but we're not really messing up too much with the configuration. Very eager to get to the bottom of this one.

@adamivancza
Copy link
Author

hey @oscb! we're using TS v5.0.4. Also we're using rnx-kit bundler and this happens to us in debug mode too, not just in release mode.

@oscb
Copy link
Contributor

oscb commented Dec 7, 2023

@adamivancza oh, interesting. Going to test out that particular version of TS. So far we have tested a few RN + TS version combinations but haven't had luck reproducing. My guess is that this could be caused by a particular (but commonly used) configuration that we haven't tried.

Any chance you could share your configuration files? In particular interested on TS, Babel, RN config (if any) ?

@adamivancza
Copy link
Author

adamivancza commented Dec 11, 2023

hey @oscb! could you email me at adam.ivancza [@] theinfatuation.com? I don't want to share anything publicly here.

@Jackman3005
Copy link

Hello 👋 , Just checking in to see if there has been any progress on this? I seem to be getting the same issue!

@oscb
Copy link
Contributor

oscb commented Jan 25, 2024

@Jackman3005 we have a release in beta right now that we think should fix this 2.18.0-beta.1.

Can you give it a try and let us know if this solves the issue? Team has been trying hard to figure this one out but we don't have a repro (but did have a hunch of what might be). Any validation would be helpful!

@hubastard
Copy link

hubastard commented Feb 1, 2024

@oscb

So, I was also getting this error and I found the issue. It's caused by a cycle dependency in ConsentPlugin.ts.

The current import looks like this:

import {
  Plugin,
  type SegmentClient,
  type DestinationPlugin,
  IntegrationSettings,
  PluginType,
  SegmentAPIIntegration,
  SegmentEvent,
  TrackEventType,
} from '..';

But it's importing on the index.ts file located in the parent folder ... But this index file also exports ConsentPlugin.ts which causes a cycle dependency and result in this error.

A quick fix is to import selectively the files that you want instead of importing them from the index to avoid the cycle dependency:

import { Plugin } from '../plugin';
import { PluginType } from '../types';
import type { IntegrationSettings, SegmentAPIIntegration, SegmentEvent, TrackEventType } from '../types';
import type { DestinationPlugin } from '../plugin';
import type { SegmentClient } from '../analytics';

@oscb
Copy link
Contributor

oscb commented Feb 9, 2024

Just released v2.18.0 with the circular dependency fix and another issue with the typings we think could be the problem. Let us know if that fixes it for you

@papaschmidt
Copy link

We have been having this issue as well. It results in unit test failing:

  ● Test suite failed to run

    TypeError: Super expression must either be null or a function

      15 |  * Plugin that injects additional user traits to every event
      16 |  */
    > 17 | export class InjectTraits extends PlatformPlugin {
         |                          ^
      18 |   type = PluginType.before;
      19 |
      20 |   async execute(event: SegmentEvent): Promise<SegmentEvent> {

      at _inherits (node_modules/@babel/runtime/helpers/inherits.js:4:11)
      at src/utils/helpers/segmentEventPlugin.ts:17:26
      at Object.<anonymous> (src/utils/helpers/segmentEventPlugin.ts:63:4)
      at Object.require (src/hooks/useSegmentClient/useSegmentClient.ts:6:1)

The error goes away if I disable the plugin, which is obviously not a solution. We are getting this on v2.7.1 (yeah, we're behind), but even upgrading to the latest version here doesn't help.

@oscb
Copy link
Contributor

oscb commented Feb 26, 2024

@papaschmidt might be a different issue as I had confirmed offline Adam's original bug here was fixed with 2.18 release.

I'm curious what's the last version of the lib you're using that works with this code?

@adamivancza
Copy link
Author

yeah, I can confirm that my original issue was resolved with the latest 2.18.0 release so we can close this issue?

@papaschmidt
Copy link

@papaschmidt might be a different issue as I had confirmed offline Adam's original bug here was fixed with 2.18 release.

I'm curious what's the last version of the lib you're using that works with this code?

This turned out to be a red herring for me. It pointed to this being an issue but it turned out something else was causing it. I don’t have this issue anymore.

Thanks

@oscb
Copy link
Contributor

oscb commented Mar 18, 2024

@papaschmidt glad to hear that! Closing this issue now

@oscb oscb closed this as completed Mar 18, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working 🚧 Work In Progress
Projects
None yet
Development

No branches or pull requests

5 participants