Add queries for Likes

This commit is contained in:
Alessio 2023-06-26 13:16:22 -03:00
parent d0ab385c52
commit fc17756a53
4 changed files with 89 additions and 0 deletions

View 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
}

View 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)
}
}

View File

@ -192,5 +192,14 @@ create table database_version(rowid integer primary key,
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);
insert into fake_user_sequence values(0x4000000000000000);

View File

@ -317,3 +317,11 @@ func create_space_from_id(id int) scraper.Space {
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),
}
}