Add queries for Likes
This commit is contained in:
parent
d0ab385c52
commit
fc17756a53
34
persistence/likes_queries.go
Normal file
34
persistence/likes_queries.go
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
package persistence
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"offline_twitter/scraper"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (p Profile) SaveLike(l scraper.Like) error {
|
||||||
|
_, err := p.DB.NamedExec(`
|
||||||
|
insert into likes (sort_order, user_id, tweet_id)
|
||||||
|
values (:sort_order, :user_id, :tweet_id)
|
||||||
|
on conflict do update set sort_order = max(sort_order, :sort_order)
|
||||||
|
`,
|
||||||
|
l,
|
||||||
|
)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("Error executing SaveLike(%#v):\n %w", l, err)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p Profile) GetLikeBySortID(id scraper.LikeSortID) (scraper.Like, error) {
|
||||||
|
var l scraper.Like
|
||||||
|
err := p.DB.Get(&l, `
|
||||||
|
select sort_order, user_id, tweet_id
|
||||||
|
from likes
|
||||||
|
where sort_order = ?
|
||||||
|
`, id)
|
||||||
|
if err != nil {
|
||||||
|
return l, fmt.Errorf("Error executing GetLikeBySortID(%d):\n %w", id, err)
|
||||||
|
}
|
||||||
|
return l, nil
|
||||||
|
}
|
38
persistence/likes_queries_test.go
Normal file
38
persistence/likes_queries_test.go
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
package persistence_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
|
||||||
|
"github.com/go-test/deep"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestSaveAndLoadLike(t *testing.T) {
|
||||||
|
require := require.New(t)
|
||||||
|
|
||||||
|
profile_path := "test_profiles/TestLikesQueries"
|
||||||
|
profile := create_or_load_profile(profile_path)
|
||||||
|
|
||||||
|
like := create_dummy_like()
|
||||||
|
err := profile.SaveLike(like)
|
||||||
|
require.NoError(err)
|
||||||
|
|
||||||
|
// Reload the Like
|
||||||
|
new_like, err := profile.GetLikeBySortID(like.SortID)
|
||||||
|
require.NoError(err)
|
||||||
|
|
||||||
|
// Should come back the same
|
||||||
|
if diff := deep.Equal(like, new_like); diff != nil {
|
||||||
|
t.Error(diff)
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test double-saving
|
||||||
|
err = profile.SaveLike(like)
|
||||||
|
require.NoError(err)
|
||||||
|
new_like, err = profile.GetLikeBySortID(like.SortID)
|
||||||
|
require.NoError(err)
|
||||||
|
if diff := deep.Equal(like, new_like); diff != nil {
|
||||||
|
t.Error(diff)
|
||||||
|
}
|
||||||
|
}
|
@ -192,5 +192,14 @@ create table database_version(rowid integer primary key,
|
|||||||
version_number integer not null unique
|
version_number integer not null unique
|
||||||
);
|
);
|
||||||
|
|
||||||
|
create table likes(rowid integer primary key,
|
||||||
|
sort_order integer unique not null,
|
||||||
|
user_id integer not null,
|
||||||
|
tweet_id integer not null,
|
||||||
|
unique(user_id, tweet_id)
|
||||||
|
foreign key(user_id) references users(id)
|
||||||
|
foreign key(tweet_id) references tweets(id)
|
||||||
|
);
|
||||||
|
|
||||||
create table fake_user_sequence(latest_fake_id integer not null);
|
create table fake_user_sequence(latest_fake_id integer not null);
|
||||||
insert into fake_user_sequence values(0x4000000000000000);
|
insert into fake_user_sequence values(0x4000000000000000);
|
||||||
|
@ -317,3 +317,11 @@ func create_space_from_id(id int) scraper.Space {
|
|||||||
ParticipantIds: []scraper.UserID{-1},
|
ParticipantIds: []scraper.UserID{-1},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func create_dummy_like() scraper.Like {
|
||||||
|
return scraper.Like{
|
||||||
|
TweetID: create_stable_tweet().ID,
|
||||||
|
UserID: create_stable_user().ID,
|
||||||
|
SortID: scraper.LikeSortID(12345),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user