Index: openacs-4/packages/faq-portlet/tcl/test/faq-portlet-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs-4/packages/faq-portlet/tcl/test/faq-portlet-procs.tcl,v diff -u -r1.4.2.4 -r1.4.2.5 --- openacs-4/packages/faq-portlet/tcl/test/faq-portlet-procs.tcl 21 Aug 2020 17:04:22 -0000 1.4.2.4 +++ openacs-4/packages/faq-portlet/tcl/test/faq-portlet-procs.tcl 5 Oct 2020 13:46:14 -0000 1.4.2.5 @@ -201,6 +201,90 @@ aa_equals "FAQ portlet pretty name" "[faq_portlet::get_pretty_name]" "#faq-portlet.pretty_name#" } +aa_register_case -procs { + faq_portlet::add_self_to_page + faq_portlet::remove_self_from_page + faq_admin_portlet::add_self_to_page + faq_admin_portlet::remove_self_from_page + } -cats { + api + } faq_portlet_add_remove_from_page { + Test add/remove portlet procs. +} { + # + # Helper proc to check portal elements + # + proc portlet_exists_p {portal_id portlet_name} { + return [db_0or1row portlet_in_portal { + select 1 from dual where exists ( + select 1 + from portal_element_map pem, + portal_pages pp + where pp.portal_id = :portal_id + and pp.page_id = pem.page_id + and pem.name = :portlet_name + ) + }] + } + # + # Start the tests + # + aa_run_with_teardown -rollback -test_code { + # + # Create a community. + # + # As this is running in a transaction, it should be cleaned up + # automatically. + # + set community_id [dotlrn_community::new -community_type dotlrn_community -pretty_name foo] + if {$community_id ne ""} { + aa_log "Community created: $community_id" + set portal_id [dotlrn_community::get_admin_portal_id -community_id $community_id] + set package_id [dotlrn::instantiate_and_mount $community_id [faq_portlet::my_package_key]] + # + # faq_portlet + # + set portlet_name [faq_portlet::get_my_name] + # + # Add portlet. + # + faq_portlet::add_self_to_page -portal_id $portal_id -package_id $package_id -param_action "" + aa_true "Portlet is in community portal after addition" "[portlet_exists_p $portal_id $portlet_name]" + # + # Remove portlet. + # + faq_portlet::remove_self_from_page -portal_id $portal_id -package_id $package_id + aa_false "Portlet is in community portal after removal" "[portlet_exists_p $portal_id $portlet_name]" + # + # Add portlet. + # + faq_portlet::add_self_to_page -portal_id $portal_id -package_id $package_id -param_action "" + aa_true "Portlet is in community portal after addition" "[portlet_exists_p $portal_id $portlet_name]" + # + # admin_portlet + # + set portlet_name [faq_admin_portlet::get_my_name] + # + # Add portlet. + # + faq_admin_portlet::add_self_to_page -portal_id $portal_id -package_id $package_id + aa_true "Admin portlet is in community portal after addition" "[portlet_exists_p $portal_id $portlet_name]" + # + # Remove portlet. + # + faq_admin_portlet::remove_self_from_page $portal_id + aa_false "Admin portlet is in community portal after removal" "[portlet_exists_p $portal_id $portlet_name]" + # + # Add portlet. + # + faq_admin_portlet::add_self_to_page -portal_id $portal_id -package_id $package_id + aa_true "Admin portlet is in community portal after addition" "[portlet_exists_p $portal_id $portlet_name]" + } else { + aa_error "Community creation failed" + } + } +} + # Local variables: # mode: tcl # tcl-indent-level: 4