-
Notifications
You must be signed in to change notification settings - Fork 80
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
Length is not correctly tracked #153
Comments
Here is a specific Action run where this failed despite having a valid tweet length: https://github.com/nodejs/tweet/pull/26/checks?check_run_id=2347151803 This might also indicate something about how the Action is counting emoji vs. how Twitter is counting emoji. |
We use https://github.com/twitter/twitter-text, it's most likely a problem with that library. I'm not sure when I'll find the time to look into this I'm afraid, if anyone could investigate and send a PR, I'd be happy to review |
From what I just tested with twitter-text, it appears that twitter-text (at least the @3.1.0) is working properly. Here is my test:
280 is the max length
A link that's obviously longer than 23 chars
the weighted length is, as expected, 23
The conclusion: It's probably not the twitter-text library. |
Thank you for testing John! |
Upon a bit more digging, I think it has something to do with the whole newline at end of file issue. I notice it from this PR https://github.com/nodejs/tweet/pull/26/files: Somehow, this "No newline at end of file" hint has been included in the preview: Which I'm highly confident that the added extra length to the original file is the cause of Here is another PR whose tweet file has newline at end of file: https://github.com/nodejs/tweet/pull/57/files and its preview looks good. A quick fix for @bnb would be to include newline at end of tweet files then. Reference: https://stackoverflow.com/questions/729692/why-should-text-files-end-with-a-newline Interestingly, even though the newline thingy is included in the preview checks, I don't think it ever gets tweeted out as part of the sent tweet. @gr2m I see you use the the same I think maybe, just maybe, somewhere around here: Btw, great work on this project @gr2m! I had the same thought of making something like twitter-together, and found you've already done an amazing job! |
I believe this should be fixed in the next release. Here's a test preview running the fix using the tweet at the top of this issue. It's validating as expected now. https://github.com/IstoraMandiri/twitter-together-testing/runs/8690276799 |
This fix should be contained within |
It should be, but it's not automatically building yet (#205), so using the 2.1.3 release still uses the 2.1.1 dist. |
Ah yep, forgot the release doesn't build :( |
What happened?
twitter-together failed on a tweet that should have worked, specifically due to line length.
What did you expect to happen?
twitter-together should have succeeded.
What the problem might be
I am fairly confident that this has to do with Twitter's link parsing. Testing out
data:image/s3,"s3://crabby-images/1aee5/1aee55679f75251757d52812f4dbacde58c1093b" alt="image"
data:image/s3,"s3://crabby-images/b4301/b43010d096bbc4137cdb7e460997bbb524791a4b" alt="image"
https://github.com/nodejs/build
as an example, the .length of that as a string is 31 but Twitter only counts it as 23 chars (note that the space before the link is taking up one char):Given that all characters (
w
s and the sapce) here count as 280 characters, the actual count is 314 but the Twitter count is 303.This occurs because under the hood, Twitter creates a t.co short link for every link that is - in total - 23 characters. It doesn't count additional characters in a URL toward the total character count, since they're only storing 23 in total. This will happen for each link, including photos.
The text was updated successfully, but these errors were encountered: