discourse/spec/system/s3_uploads_spec.rb
Joffrey JAFFEUX c70e18faa0
DEV: updates playwright to 1.54 (#33715)
Relevant info:

bb2dcadfd3

https://playwright.dev/docs/release-notes#version-153

https://playwright.dev/docs/release-notes#version-154

Note this commit introduces `wait_for_timeout` which should only be used in very rare and specific case. Aa much as possible developers have to find a way to provide a change in the DOM to hook their assertions to it.
2025-07-24 10:07:31 +02:00

53 lines
1.7 KiB
Ruby

# frozen_string_literal: true
describe "Uploading files in the composer to S3", type: :system do
fab!(:current_user, :admin)
let(:modal) { PageObjects::Modals::Base.new }
let(:composer) { PageObjects::Components::Composer.new }
let(:topic) { PageObjects::Pages::Topic.new }
describe "direct S3 uploads" do
describe "single part uploads" do
it "uploads custom avatars to S3" do
setup_or_skip_s3_system_test
sign_in(current_user)
visit "/my/preferences/account"
find("#edit-avatar").click
find("#uploaded-avatar").click
attach_file(
"custom-profile-upload",
File.absolute_path(file_from_fixtures("logo.jpg")),
make_visible: true,
)
expect(page).to have_css(".avatar-uploader .avatar-uploader__button[data-uploaded]")
modal.click_primary_button
expect(modal).to be_closed
expect(page).to have_css(
"#user-avatar-uploads[data-custom-avatar-upload-id]",
visible: :hidden,
)
expect(current_user.reload.uploaded_avatar_id).to eq(
find("#user-avatar-uploads", visible: false)["data-custom-avatar-upload-id"].to_i,
)
end
end
describe "multipart uploads" do
xit "uploads a file in the post composer" do
setup_or_skip_s3_system_test
sign_in(current_user)
topic.open_new_topic
file_path = file_from_fixtures("logo.png", "images").path
attach_file("file-uploader", file_path, make_visible: true)
expect(page).to have_no_css("#file-uploading")
expect(composer.preview).to have_css(".image-wrapper")
end
end
end
end