# Redmine - project management software # Copyright (C) 2006-2016 Jean-Philippe Lang # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. require File.expand_path('../../test_helper', __FILE__) class JournalTest < ActiveSupport::TestCase fixtures :projects, :issues, :issue_statuses, :journals, :journal_details, :issue_relations, :workflows, :users, :members, :member_roles, :roles, :enabled_modules, :groups_users, :email_addresses, :enumerations, :projects_trackers, :trackers, :custom_fields def setup @journal = Journal.find 1 User.current = nil end def test_journalized_is_an_issue issue = @journal.issue assert_kind_of Issue, issue assert_equal 1, issue.id end def test_new_status status = @journal.new_status assert_not_nil status assert_kind_of IssueStatus, status assert_equal 2, status.id end def test_create_should_send_email_notification ActionMailer::Base.deliveries.clear issue = Issue.first user = User.first journal = issue.init_journal(user, issue) assert journal.save assert_equal 1, ActionMailer::Base.deliveries.size end def test_should_not_save_journal_with_blank_notes_and_no_details journal = Journal.new(:journalized => Issue.first, :user => User.first) assert_no_difference 'Journal.count' do assert_equal false, journal.save end end def test_create_should_not_split_non_private_notes assert_difference 'Journal.count' do assert_no_difference 'JournalDetail.count' do journal = Journal.generate!(:notes => 'Notes') end end assert_difference 'Journal.count' do assert_difference 'JournalDetail.count' do journal = Journal.generate!(:notes => 'Notes', :details => [JournalDetail.new]) end end assert_difference 'Journal.count' do assert_difference 'JournalDetail.count' do journal = Journal.generate!(:notes => '', :details => [JournalDetail.new]) end end end def test_create_should_split_private_notes assert_difference 'Journal.count' do assert_no_difference 'JournalDetail.count' do journal = Journal.generate!(:notes => 'Notes', :private_notes => true) journal.reload assert_equal true, journal.private_notes assert_equal 'Notes', journal.notes end end assert_difference 'Journal.count', 2 do assert_difference 'JournalDetail.count' do journal = Journal.generate!(:notes => 'Notes', :private_notes => true, :details => [JournalDetail.new]) journal.reload assert_equal true, journal.private_notes assert_equal 'Notes', journal.notes assert_equal 0, journal.details.size journal_with_changes = Journal.order('id DESC').offset(1).first assert_equal false, journal_with_changes.private_notes assert_nil journal_with_changes.notes assert_equal 1, journal_with_changes.details.size assert_equal journal.created_on, journal_with_changes.created_on end end assert_difference 'Journal.count' do assert_difference 'JournalDetail.count' do journal = Journal.generate!(:notes => '', :private_notes => true, :details => [JournalDetail.new]) journal.reload assert_equal false, journal.private_notes assert_equal '', journal.notes assert_equal 1, journal.details.size end end end def test_visible_scope_for_anonymous # Anonymous user should see issues of public projects only journals = Journal.visible(User.anonymous).to_a assert journals.any? assert_nil journals.detect {|journal| !journal.issue.project.is_public?} # Anonymous user should not see issues without permission Role.anonymous.remove_permission!(:view_issues) journals = Journal.visible(User.anonymous).to_a assert journals.empty? end def test_visible_scope_for_user user = User.find(9) assert user.projects.empty? # Non member user should see issues of public projects only journals = Journal.visible(user).to_a assert journals.any? assert_nil journals.detect {|journal| !journal.issue.project.is_public?} # Non member user should not see issues without permission Role.non_member.remove_permission!(:view_issues) user.reload journals = Journal.visible(user).to_a assert journals.empty? # User should see issues of projects for which user has view_issues permissions only Member.create!(:principal => user, :project_id => 1, :role_ids => [1]) user.reload journals = Journal.visible(user).to_a assert journals.any? assert_nil journals.detect {|journal| journal.issue.project_id != 1} end def test_visible_scope_for_admin user = User.find(1) user.members.each(&:destroy) assert user.projects.empty? journals = Journal.visible(user).to_a assert journals.any? # Admin should see issues on private projects that admin does not belong to assert journals.detect {|journal| !journal.issue.project.is_public?} end def test_preload_journals_details_custom_fields_should_set_custom_field_instance_variable d = JournalDetail.new(:property => 'cf', :prop_key => '2') journals = [Journal.new(:details => [d])] d.expects(:instance_variable_set).with("@custom_field", CustomField.find(2)).once Journal.preload_journals_details_custom_fields(journals) end def test_preload_journals_details_custom_fields_with_empty_set assert_nothing_raised do Journal.preload_journals_details_custom_fields([]) end end def test_details_should_normalize_dates j = JournalDetail.create!(:old_value => Date.parse('2012-11-03'), :value => Date.parse('2013-01-02')) j.reload assert_equal '2012-11-03', j.old_value assert_equal '2013-01-02', j.value end def test_details_should_normalize_true_values j = JournalDetail.create!(:old_value => true, :value => true) j.reload assert_equal '1', j.old_value assert_equal '1', j.value end def test_details_should_normalize_false_values j = JournalDetail.create!(:old_value => false, :value => false) j.reload assert_equal '0', j.old_value assert_equal '0', j.value end def test_custom_field_should_return_custom_field_for_cf_detail d = JournalDetail.new(:property => 'cf', :prop_key => '2') assert_equal CustomField.find(2), d.custom_field end def test_custom_field_should_return_nil_for_non_cf_detail d = JournalDetail.new(:property => 'subject') assert_nil d.custom_field end def test_visible_details_should_include_relations_to_visible_issues_only issue = Issue.generate! visible_issue = Issue.generate! hidden_issue = Issue.generate!(:is_private => true) journal = Journal.new journal.details << JournalDetail.new(:property => 'relation', :prop_key => 'relates', :value => visible_issue.id) journal.details << JournalDetail.new(:property => 'relation', :prop_key => 'relates', :value => hidden_issue.id) visible_details = journal.visible_details(User.anonymous) assert_equal 1, visible_details.size assert_equal visible_issue.id.to_s, visible_details.first.value.to_s visible_details = journal.visible_details(User.find(2)) assert_equal 2, visible_details.size end end 8-update-psalm-baseline'>automated/noid/stable28-update-psalm-baseline Nextcloud server, a safe home for all your data: https://github.com/nextcloud/serverwww-data
summaryrefslogtreecommitdiffstats
path: root/apps/comments/l10n/ja.json
blob: 2465b3de8e9780ed61eb43bad341198db0813ce8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
{ "translations": {
    "Comments" : "コメント",
    "Unknown user" : "不明なユーザー",
    "New comment …" : "新しいコメント...",
    "Delete comment" : "コメントを削除",
    "Post" : "追加",
    "Cancel" : "キャンセル",
    "Edit comment" : "コメントを編集",
    "[Deleted user]" : "[削除済みユーザー]",
    "No comments yet, start the conversation!" : "まだコメントはありません、会話を開始してください!",
    "More comments …" : "その他のコメント...",
    "Save" : "保存",
    "Allowed characters {count} of {max}" : "入力文字数  {count} / {max}",
    "Error occurred while retrieving comment with id {id}" : "コメントID {id} のコメントを取得する際にエラーが発生",
    "Error occurred while updating comment with id {id}" : "コメントID {id} のコメントをアップロードする際にエラーが発生",
    "Error occurred while posting comment" : "コメント投稿時にエラーが発生",
    "_%n unread comment_::_%n unread comments_" : ["%n の未読のコメント"],
    "Comment" : "コメント",
    "You commented" : "コメント済",
    "%1$s commented" : "%1$s がコメントを追加",
    "{author} commented" : "{author} がコメントしました",
    "You commented on %1$s" : "%1$s にコメントしました",
    "You commented on {file}" : "{file} にコメントしました",
    "%1$s commented on %2$s" : "%2$s について、%1$s がコメントしました",
    "{author} commented on {file}" : "{author} が{file} にコメントしました",
    "<strong>Comments</strong> for files" : "ファイルの<strong>コメント</ strong>",
    "A (now) deleted user mentioned you in a comment on \"%s\"." : "”%s\" のコメントであなたについて削除(もしくは今)されたユーザーがコメントしました。",
    "%s mentioned you in a comment on \"%s\"." : "%s さんが\"%s\"のコメントであなたについて言及しました。",
    "Type in a new comment..." : "新しいコメントを入力...",
    "No other comments available" : "コメントはありません",
    "More comments..." : "コメントをさらに表示...",
    "{count} unread comments" : "未読コメント数 {count}",
    "You commented on %2$s" : "%2$s にコメント済"
},"pluralForm" :"nplurals=1; plural=0;"
}