sdk: more PrepareNote() tests.
This commit is contained in:
@@ -99,9 +99,8 @@ func TestStreamLiveFeed(t *testing.T) {
|
||||
relay.Close()
|
||||
|
||||
// create a new system instance pointing only to relay1 as the "indexer"
|
||||
sys := NewSystem(WithRelayListRelays([]string{
|
||||
"ws://localhost:48481",
|
||||
}))
|
||||
sys := NewSystem()
|
||||
sys.RelayListRelays = NewRelayStream("ws://localhost:48481")
|
||||
defer sys.Close()
|
||||
|
||||
// prepublish some events
|
||||
|
||||
15
sdk/note.go
15
sdk/note.go
@@ -13,9 +13,9 @@ import (
|
||||
)
|
||||
|
||||
var (
|
||||
domainRe = regexp.MustCompile(`(?:https?:\/\/)?([a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*\.(?:[a-zA-Z]{2,})`)
|
||||
nostrRe = regexp.MustCompile(`(?:nostr:)?(npub|nprofile|naddr|nevent|note)1([a-zA-Z0-9]+`)
|
||||
tagRe = regexp.MustCompile(`\b#+\w+`)
|
||||
domainRe = regexp.MustCompile(`\b(?:https?:\/\/)?([a-zA-Z0-9-]+(?:\.[a-zA-Z0-9-]+)*\.(?:[a-zA-Z]{2,}))`)
|
||||
nostrRe = regexp.MustCompile(`\b(?:nostr:)?(npub|nprofile|naddr|nevent|note)1([a-zA-Z0-9]+)`)
|
||||
tagRe = regexp.MustCompile(`^#+\w+\b|\s#+\w+\b`)
|
||||
)
|
||||
|
||||
// PrepareNoteEvent takes an event with content that may include any number of URLs, partial URLs without the scheme, npub references with or without the "nostr:" prefix, tags and whatnot, then edits the content so it contains properly formatted URLs and references and adds the required tags based on these.
|
||||
@@ -82,12 +82,17 @@ func (sys *System) PrepareNoteEvent(ctx context.Context, evt *nostr.Event) (targ
|
||||
tag = append(tag, relay) // shove this relay hint here
|
||||
}
|
||||
} else {
|
||||
evt.Tags = append(evt.Tags, append(b.AsTag(), relay))
|
||||
b.Relays = append(b.Relays, relay)
|
||||
tag = b.AsTag()
|
||||
tag[0] = "q"
|
||||
evt.Tags = append(evt.Tags, tag)
|
||||
}
|
||||
case nostr.EntityPointer:
|
||||
pk = b.PublicKey
|
||||
if tag := evt.Tags.FindWithValue("q", b.AsTagReference()); tag == nil {
|
||||
evt.Tags = append(evt.Tags, b.AsTag())
|
||||
tag := b.AsTag()
|
||||
tag[0] = "q"
|
||||
evt.Tags = append(evt.Tags, tag)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
package sdk
|
||||
|
||||
import (
|
||||
"context"
|
||||
"testing"
|
||||
|
||||
"fiatjaf.com/nostr"
|
||||
@@ -8,33 +9,82 @@ import (
|
||||
)
|
||||
|
||||
func TestPrepareNoteEvent(t *testing.T) {
|
||||
// prepare a dummy system, it's needed for context but won't be used in these specific tests
|
||||
sys := NewSystem()
|
||||
defer sys.Close()
|
||||
ctx := context.Background()
|
||||
|
||||
tests := []struct {
|
||||
name string
|
||||
content string
|
||||
wantTags nostr.Tags
|
||||
want string
|
||||
tags nostr.Tags // initial tags
|
||||
wantTags nostr.Tags // expected tags after processing
|
||||
want string // expected content after processing
|
||||
}{
|
||||
{
|
||||
name: "plain text",
|
||||
content: "hello world",
|
||||
tags: nostr.Tags{},
|
||||
wantTags: nostr.Tags{},
|
||||
want: "hello world",
|
||||
},
|
||||
{
|
||||
name: "with nostr: prefix, url and hashtag",
|
||||
content: "hello nostr:npub180cvv07tjdrrgpa0j7j7tmnyl2yr6yr7l8j4s3evf6u64th6gkwsyjh6w6 please visit https://banana.com/ and get your free #banana",
|
||||
tags: nostr.Tags{},
|
||||
wantTags: nostr.Tags{
|
||||
{"p", "82341f882b6eabcd2ba7f1ef90aad961cf074af15b9ef44a09f9d2a8fbfbe6a2"},
|
||||
{"p", "3bf0c63fcb93463407af97a5e5ee64fa883d107ef9e558472c4eb9aaaefa459d"},
|
||||
{"t", "banana"},
|
||||
},
|
||||
want: "hello nostr:npub180cvv07tjdrrgpa0j7j7tmnyl2yr6yr7l8j4s3evf6u64th6gkwsyjh6w6 please visit https://banana.com/ and get your free #banana",
|
||||
},
|
||||
{
|
||||
name: "with bare npub and bare url",
|
||||
content: "hello npub180cvv07tjdrrgpa0j7j7tmnyl2yr6yr7l8j4s3evf6u64th6gkwsyjh6w6 please visit banana.com",
|
||||
tags: nostr.Tags{},
|
||||
wantTags: nostr.Tags{
|
||||
{"p", "82341f882b6eabcd2ba7f1ef90aad961cf074af15b9ef44a09f9d2a8fbfbe6a2"},
|
||||
{"p", "3bf0c63fcb93463407af97a5e5ee64fa883d107ef9e558472c4eb9aaaefa459d"},
|
||||
},
|
||||
want: "hello nostr:npub180cvv07tjdrrgpa0j7j7tmnyl2yr6yr7l8j4s3evf6u64th6gkwsyjh6w6 please visit banana.com",
|
||||
want: "hello nostr:npub180cvv07tjdrrgpa0j7j7tmnyl2yr6yr7l8j4s3evf6u64th6gkwsyjh6w6 please visit https://banana.com",
|
||||
},
|
||||
{
|
||||
name: "content with a single hashtag",
|
||||
content: "#this is a test with #nostr",
|
||||
tags: nostr.Tags{},
|
||||
wantTags: nostr.Tags{
|
||||
{"t", "nostr"},
|
||||
{"t", "this"},
|
||||
},
|
||||
want: "#this is a test with #nostr",
|
||||
},
|
||||
{
|
||||
name: "content with multiple hashtags",
|
||||
content: "testing #multiple #hashtags here",
|
||||
tags: nostr.Tags{},
|
||||
wantTags: nostr.Tags{
|
||||
{"t", "multiple"},
|
||||
{"t", "hashtags"},
|
||||
},
|
||||
want: "testing #multiple #hashtags here",
|
||||
},
|
||||
{
|
||||
name: "content with existing t tag",
|
||||
content: "when adding #tags don't add duplicate #tags to banana.social",
|
||||
tags: nostr.Tags{{"t", "tags"}},
|
||||
wantTags: nostr.Tags{
|
||||
{"t", "tags"},
|
||||
},
|
||||
want: "when adding #tags don't add duplicate #tags to https://banana.social",
|
||||
},
|
||||
{
|
||||
name: "content with mixed tags and hashtag",
|
||||
content: "a valid nevent1qqsr0f9w78uyy09qwmjt0kv63j4l7sxahq33725lqyyp79whlfjurwspz4mhxue69uhh56nzv34hxcfwv9ehw6nyddhqygpm7rrrljungc6q0tuh5hj7ue863q73qlheu4vywtzwhx42a7j9n5x0aedk and an invalid nevent1aaa",
|
||||
tags: nostr.Tags{{"t", "unrelated"}},
|
||||
wantTags: nostr.Tags{
|
||||
{"t", "unrelated"},
|
||||
{"q", "37a4aef1f8423ca076e4b7d99a8cabff40ddb8231f2a9f01081f15d7fa65c1ba", "wss://zjbdksa.aswjdkn", "3bf0c63fcb93463407af97a5e5ee64fa883d107ef9e558472c4eb9aaaefa459d"},
|
||||
},
|
||||
want: "a valid nostr:nevent1qqsr0f9w78uyy09qwmjt0kv63j4l7sxahq33725lqyyp79whlfjurwspz4mhxue69uhh56nzv34hxcfwv9ehw6nyddhqygpm7rrrljungc6q0tuh5hj7ue863q73qlheu4vywtzwhx42a7j9n5x0aedk and an invalid nevent1aaa",
|
||||
},
|
||||
}
|
||||
|
||||
@@ -42,12 +92,12 @@ func TestPrepareNoteEvent(t *testing.T) {
|
||||
t.Run(tt.name, func(t *testing.T) {
|
||||
evt := &nostr.Event{
|
||||
Content: tt.content,
|
||||
Tags: nostr.Tags{},
|
||||
Tags: tt.tags.Clone(),
|
||||
}
|
||||
|
||||
PrepareNoteEvent(evt)
|
||||
sys.PrepareNoteEvent(ctx, evt)
|
||||
require.Equal(t, tt.want, evt.Content)
|
||||
require.Equal(t, tt.wantTags, evt.Tags)
|
||||
require.ElementsMatch(t, tt.wantTags, evt.Tags, "tags mismatch")
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user