DEV: Populate first and last seen at timestamps. (#17643)

discourse-chat's auto-join users rely on these values, so it's handy for the populate task to set them.
This commit is contained in:
Roman Rizzi 2022-07-25 11:54:43 -03:00 committed by GitHub
parent 424a274c12
commit 6df36247c1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 16 additions and 12 deletions

View File

@ -1,7 +1,7 @@
# frozen_string_literal: true # frozen_string_literal: true
require 'discourse_dev/record' require "discourse_dev/record"
require 'faker' require "faker"
module DiscourseDev module DiscourseDev
class User < Record class User < Record
@ -19,6 +19,8 @@ module DiscourseDev
username = Faker::Internet.unique.username(specifier: ::User.username_length) username = Faker::Internet.unique.username(specifier: ::User.username_length)
username = UserNameSuggester.suggest(username) username = UserNameSuggester.suggest(username)
username_lower = ::User.normalize_username(username) username_lower = ::User.normalize_username(username)
created_at = Faker::Time.between(from: DiscourseDev.config.start_date, to: DateTime.now)
seen_at = Faker::Time.between(from: created_at, to: DateTime.now)
{ {
name: name, name: name,
@ -27,7 +29,9 @@ module DiscourseDev
username_lower: username_lower, username_lower: username_lower,
moderator: Faker::Boolean.boolean(true_ratio: 0.1), moderator: Faker::Boolean.boolean(true_ratio: 0.1),
trust_level: Faker::Number.between(from: 1, to: 4), trust_level: Faker::Number.between(from: 1, to: 4),
created_at: Faker::Time.between(from: DiscourseDev.config.start_date, to: DateTime.now), created_at: created_at,
first_seen_at: seen_at,
last_seen_at: seen_at,
} }
end end
@ -35,11 +39,13 @@ module DiscourseDev
super do |user| super do |user|
user.activate user.activate
set_random_avatar(user) set_random_avatar(user)
Faker::Number.between(from: 0, to: 2).times do Faker::Number
group = Group.random .between(from: 0, to: 2)
.times do
group = Group.random
group.add(user) group.add(user)
end end
end end
end end
@ -70,7 +76,7 @@ module DiscourseDev
STDERR.puts "Failed to upload avatar for user #{user.username}: #{avatar_path}" STDERR.puts "Failed to upload avatar for user #{user.username}: #{avatar_path}"
STDERR.puts upload.errors.inspect if upload STDERR.puts upload.errors.inspect if upload
end end
rescue rescue StandardError
STDERR.puts "Failed to create avatar for user #{user.username}: #{avatar_path}" STDERR.puts "Failed to create avatar for user #{user.username}: #{avatar_path}"
ensure ensure
tempfile.close! if tempfile tempfile.close! if tempfile
@ -80,11 +86,9 @@ module DiscourseDev
def copy_to_tempfile(source_path) def copy_to_tempfile(source_path)
extension = File.extname(source_path) extension = File.extname(source_path)
tmp = Tempfile.new(['discourse-upload', extension]) tmp = Tempfile.new(["discourse-upload", extension])
File.open(source_path) do |source_stream| File.open(source_path) { |source_stream| IO.copy_stream(source_stream, tmp) }
IO.copy_stream(source_stream, tmp)
end
tmp.rewind tmp.rewind
tmp tmp